#### ADDITIONAL MAXWELL MACMILLAN INTERNATIONAL EDITIONS IN COMPUTER SCIENCE

Adamson Antonakos Ellzey Hair Irvine Johnsonbaugh Khan Kroenke Leestma Loomis Mayer Nyhoff Ricardo Stallings Stallings

STRUCTURED C FOR TECHNOLOGY THE 68000 MICROPROCESSOR DATA STRUCTURES FOR COMPUTER INFORMATION SYSTEMS/2e MULTIVARIATE DATA ANALYSIS/2e ASSEMBLY LANGUAGE FOR THE IBM-PC APPLICATIONS PROGRAMMING IN C BEGINNING STRUCTURED COBOL DATABASE PROCESSING/3e PASCAL PROGRAMMING & PROBLEM SOLVING/3e THE DATABASE BOOK **PROGRAMMING IN MODULA-2** DATA STRUCTURES & PROGRAM DESIGN IN MODULA-2 DATABASE SYSTEMS: PRINCIPLES, DESIGN & IMPLEMENTATION COMPUTER ORGANIZATION & ARCHITECTURE/2e DATA & COMPUTER COMMUNICATIONS/2e ISDN: AN INTRODUCTION Stallings Stallings LOCAL NETWORKS/3e

**INTRODUCTION TO COMPUTERS & INFORMATION** Szymanski SYSTEMS/2e

# 16/32-BIT MICROPROCESSORS 68000/68010/68020 Software, Hardware, and Design Applications

### PUTER SCIENCE COMPUTER SCIENCE COMPUTER SCIENCE COMPUTER SCIENCE COMPUTER SCIENCE COMPUTER SCIENCE COMP



MAXWELL MACMILLAN **INTERNATIONAL** EDITIONS



School Structure School School

**CESSO** 

MAXWELL MACMILLAN INTERNATIONAL **EDITIONS** 

### PUTER SCIENCE COMPUTER SCIENCE COMPUTER SCIENCE COMPUTER SCIENCE COMPUTER SCIENCE COMPUTER SCIENCE COMP

ISBN 0-02-946331-9

WUNNAVA V. SUBBARAO

WUNNAVA V. SUBBARAO Florida International University

Merrill, an imprint of Macmillan Publishing Company New York

Collier Macmillan Canada, Inc. Toronto

Maxwell Macmillan International Publishing Group New York Oxford Singapore Sydney

# 16/32-Bit Microprocessors: 68000/68010/68020 Software, Hardware, and Design Applications

© Copyright 1991 by Macmillan Publishing Company. Merrill is an imprint of Macmillan Publishing Company.

Printed in the Republic of Singapore

All rights reserved. No part of this book may be reproduced or transmitted in any form or by any means, electronic or mechanical, including photocopying, recording, or any information storage and retrieval system, without permission in writing from the publisher.

Distribution rights in this edition are controlled exclusively by Maxwell Macmillan Publishing Singapore Pte. Ltd. and restricted to selected countries. This book may be sold only in the country to which it has been sold or consigned by Maxwell Macmillan Publishing Singapore Pte. Ltd. Re-export to any other country is unauthorized and a violation of the rights of the copyright proprietor.

Macmillan Publishing Company 866 Third Avenue, New York, New York 10022

Collier Macmillan Canada, Inc.

Library of Congress Catalog Card Number: 90-60538

ISBN 0-675-21119-0 (Hardcover Edition) ISBN 0-02-946331-9 (International Edition)

IE Printing: 1 2 3 4 5 Year: 1 2 3 4 5

I2BN 0-05-84P337-8

To the respectful memory of my professors

Dr. Earnest Anderson, Ph.D., P.E., North Dakota State University, Fargo, and Dr. S. Jnanananda, Ph.D., D.Sc., Andhra University, Waltair, Andhra Pradesh, India. for their perseverance, compassion, and interest in my education,

and

I could venture and complete this project

To the Department of Electrical and Computer Engineering, Florida International University, Miami, for providing me with an outstanding professional atmosphere in which

In recent years, the single most important development in the field of digital electronics has been the microprocessor. Thanks to VLSI (very-large-scale integration), it has grown from the simple 4-bit processing element of a quarter-century ago to the complex 32/64-bit processing unit of the present time.

The Intel and Motorola corporations have been leaders in the development of microprocessors and associated electronic circuits. Currently, the two frontrunning families of microprocessors are the Intel 8086/186/286/386 family and the Motorola 68000/10/ 20/30 family. The Intel processors are very popular in such personal computers as the IBM PC and compatibles. The Motorola processors are equally popular in such personal computers as Apple's Macintosh, Commodore's Amiga, and Atari's ST. Most industrial controllers and systems, such as image-processing systems, robotic systems, and communication systems, are based on the Motorola 68000 family.

This book focuses on the Motorola family of microprocessors. It is written as a college-level text for electrical engineering and technology students, computer engineering and technology students, and computer science students. It can also serve as a self-teaching text for practicing engineering and technical personnel.

The book examines general software and hardware concepts of microprocessors, as well as microprocessor-based system design and implementation schemes, with specific reference to the 68000 family of processors. Descriptions of the software and hardware are sufficiently detailed to enable the reader to make use of the concepts in practical applications. Most of the software and hardware discussions are based on actual working models.

The 68000 family consists of the 16-bit 68000 processor, the 8-bit 68008 processor, the 16-bit virtual memory 68010 processor, the enhanced virtual memory 68012

## PREFACE

processor, the 32-bit cache memory 68020 processor, and the 32-bit enhanced cache memory 68030 processor. All of the later versions are based on the original 68000. Coverage of the text includes the architecture, software, hardware, and application details of the 68000 processor, with concepts extended to the other family members. Assembly programming techniques, parallel and serial I/O (input/output) interface techniques and associated applications, interrupt and DMA (direct memory access) applications, and system implementation schemes have been given particular emphasis.

**Chapter 1** presents the basic concepts of the 68000 family of microprocessors and introduces the architecture of the 68000. The special features of the 68000 family are also described. In **Chapter 2** the memory organization schemes, data structures, and addressing modes associated with the 68000 are covered, along with the instruction format and structure typical of the 68000 family. The instruction set of the 68000 is presented in **Chapter 3**, with particular emphasis on the general flow of the instruction structure, the instruction timing, and the instruction groups.

**Chapter 4** deals with software and programming techniques and applications of the 68000 processor. Assembly programming methods and special software features such as macros are examined in detail. The important aspect of exception processing is covered in **Chapter 5.** In this chapter, exception processing resulting from interrupts and error conditions is described.

**Chapter** 6 deals with the hardware structure of the 68000 processor and the interfacing techniques with the memory and I/O. Important hardware concepts, such as address decoding, read and write bus cycle timing, and the VME and VERSA busing schemes, are introduced. This provides a foundation for the discussion on the parallel I/O interface to the 68000 and associated applications in **Chapter** 7. Important parallel interface devices, such as the 6821 PIA and 68230 PI/T, are introduced in this chapter. Data entry and display applications and position control using stepper motors are presented, along with hardware and software details. This leads to a description of the serial I/O interface to the 68000 and associated applications in **Chapter 8.** Industry standard serial interface devices, such as the 6850 ACIA and 68901 MFP, are introduced. RS-232 serial data communication and coded data transmission applications are presented, including hardware and software details.

**Chapter** 9 deals with the most important aspects of the interrupts and the DMA (direct memory access) schemes associated with the 68000. Such practical applications as the daisy chain of interrupts, interrupt-driven gain controllers, and interrupt-driven data-acquisition systems with A/D and D/A are presented, again with hardware and software details. General concepts of the DMA are presented through a practical application using DMA-based high-speed data transfers.

**Chapter** 10 introduces the 68010 virtual memory processor. The general concepts of virtual memory, virtual machines, and the operating system are discussed in detail. The additional resources of the 68010 and 68012 processors are also covered, along with memory-access fault correction schemes using virtual memory concepts.

In **chapter** 11 the 32-bit 68020 and 68030 cache memory processors are introduced. The concepts of cache memory organization are discussed. Additional resources of the 68020 and 68030 processors and related performance improvements are presented. An objective comparison between the 68000 and the 68020/30 is also included to provide insight into the applications of these very powerful processors.

Finally, the book includes four appendices: Appendix A on number systems, Appendix B on the 68000 instruction set and condition uses, Appendix C on analog and digital converter devices for interfacing, and Appendix D on instruction timing for the 68000/10 processors.

The material is designed to be used in a two-semester course. For engineering and technical students, Chapters 1, 2, 3, 4, 5, and 6 can be covered in the first semester. In the second semester, Chapters 7, 8, 9, 10, and 11 can be covered. For computer science and software-oriented students, Chapters 1, 2, 3, 4, 5, and 10 can be covered in one semester. If instructors choose to introduce hardware before dealing with exceptions, they can switch the order of presentation of Chapters 5 and 6.

Each chapter is organized into four or five main sections, each dealing with an important topic. In most cases, each section has at least one example problem. The end-of-chapter problems are especially designed to supplement the material covered in the book. Most of these problems have been classroom tested. A comprehensive glossary is included at the end of the book.

The book is an outgrowth of several courses on microprocessors and digital systems taught by the author at Florida International University to engineering, technology. and computer science students. The author's association with the Motorola Corporation as a consulting professor, teaching their industrial seminars on the 68000 family of processors and applications, also significantly contributed to the book's development.

Nothing replaces a hands-on learning experience. Therefore, readers are encouraged to apply the software and hardware concepts introduced in this book to practical problems using the microcomputer system of their choice.

#### Acknowledgments

Many people assisted me in the preparation of this book. Students in the Electrical Engineering and Computer Science departments at Florida International University were extremely helpful. In particular, I would like to thank Jorge Salinger, Laura Ruiz, Mauracio Salinas, Fernando Gonzalez, and Mike Urucinitz of the Electrical Engineering Department for their work in conducting hardware and software experiments to support the discussions in this book.

Motorola Corporation has been very generous in donating 68000- and 68020-based systems to the university. This allowed for the concepts presented in the text to be tested on real systems. Special thanks to Ben Ledonne and Fritz Wilson of the university support service at the Motorola Corporation in Phoenix for their support and encouragement.

I would like to acknowledge the encouragement and guidance offered by our chairperson, James Story, and the professional courtesy extended to me by our dean. Gordon Hopkins, and associate dean, Manuel Cereijo, during the preparation of the book. Many thanks also to Lie Lonie Boney and Lordis Barough for their assistance in preparing the materials for presentation. I am especially grateful to my wife, Sunanda.

and to my children, Madhavi and Manoj, for their immense patience and understanding during the course of the project.

Perhaps no words can express my gratitude to my teachers. They have given me a path objective, a career, and, above all, knowledge and self-esteem. Professor Earnest Anderson and Professor Edwin Anderson of North Dakota State University in Fargo and Professor D.L. Sastry, the late Professor S. Jnanananda, and Professor D.S. Sastry of Andhra University in Waltair and Masulipatam in India have been instrumental in shaping my present academic career. I remain ever grateful to them. I would also like to thank the reviewers of this edition for their important ideas and suggestions: Antony Alumkal, Austin Community College; Mike Bachelder, South Dakota School of Mines and Technology; Gary Boyington, Chemeketa Community College; George Frueh, Lincoln Technical Institute; Frank Gergelyi, Metropolitan Technical Institute; Jerry Noe, Tri Cities State Technical School; and John Skroder, Texas A&M University.

#### INTRODUCTION

#### CHAPTER 1 The 68000 Family of Microprocessors and Architecture

### 1.0 INTRODUCTION 2

- 1.1 The 68000 FAMILY OF MICROPROCESSORS 2
  - The 68000 Microprocessor 2
  - The 68008 Microprocessor 2
  - The 68010 Microprocessor 3
  - The 68012 Microprocessor
  - The 68020 Microprocessor 4
  - The 68030 Microprocessor 4
  - The 68881 Coprocessor
- 1.2 TYPICAL MICROCOMPUTER CONFIGURATION OF THE 68000 FAMILY 5 General Interface Scheme 5 Typical 68000-Based Systems 6
- 1.3 GENERAL ARCHITECTURE OF THE 68000 MICROPROCESSOR 7 Data Registers D0-D7 (Dn) 7 Address Registers A0-A6 (An) 8 Stack Pointers A7 (USP) and A7' (SSP) 8 Program Counter (PC) 9 Status Register (SR) and Flag Structure 9 Other Resources 12 Supervisor and User Modes of Operation

# CONTENTS

xix

1

13

xi

| 1.4        | OTHER FEATURES OF THE 68000 FAMILY OF PROCESSORS 15<br>Prefetch Queue 15<br>The Instruction Pipeline 15                                                                                                                                                                                                                                                           |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1.5        | SUMMARY 15<br>PROBLEMS 16<br>ENDNOTES 18                                                                                                                                                                                                                                                                                                                          |
| The        | APTER 2<br>e 68000 Memory Organization Schemes, Data<br>uctures, and Addressing Modes                                                                                                                                                                                                                                                                             |
| 2.0<br>2.1 | INTRODUCTION20MEMORY ORGANIZATION SCHEMES AND DATA STRUCTURES20Memory Organization and Selection Schemes20Data Structures and Representation21Stack and Queue Organization and Structure for the 6800024                                                                                                                                                          |
| 2.2        | INSTRUCTION FORMAT AND STRUCTURE26Instruction Format27Instruction Structure7                                                                                                                                                                                                                                                                                      |
| 2.3        | REGISTER DIRECT AND REGISTER INDIRECTADDRESSING MODES28 RegisterDirect Addressing Modes30 RegisterIndirect Addressing Modes30                                                                                                                                                                                                                                     |
| 2.4        | IMMEDIATE, QUICK, ABSOLUTE, RELATIVE,<br>AND IMPLICIT ADDRESSING MODES 34Immediate Addressing Mode (Imm) 35 QuickAddressing Mode (Q) 35Absolute Short and Long Addressing Modes (Abs.W, Abs.L) 36 PC Relative<br>with Displacement Addressing Mode d(PC) 37 PC Relative with Index and<br>Displacement Addressing Mode d(PC,Rn) 37 Implicit Addressing Mode<br>38 |
| 2.5        | SUMMARY 39<br>PROBLEMS 41<br>ENDNOTES 43                                                                                                                                                                                                                                                                                                                          |
| -          | APTER 3<br>68000 Instruction Set and Programming Considerations                                                                                                                                                                                                                                                                                                   |
| 3.0<br>3.1 | INTRODUCTION45THE GENERAL INSTRUCTION SET45Interpretation of the Instructions45The Instruction Groups50                                                                                                                                                                                                                                                           |
| 3.2        | DATA MOVEMENT AND ARITHMETIC INSTRUCTION GROUPS 52                                                                                                                                                                                                                                                                                                                |

- Data Movement Instructions 52
- Binary Integer Arithmetic Instructions 55 BCD

(Binary Coded Decimal) Instructions 62

3.3 LOGICAL AND BIT-MANIPULATION Logic, Shift, and Rotate Instructions Bit-Manipulation Instructions 70

- 3.4 PROGRAM AND SYSTEM CONTROL INSTRUCTION GROUPS Program Control Instructions 73 System Control Instructions 76
- 3.5 INSTRUCTION TIMING CONSIDERATIONS 78 Read/Write Timing 78 Instruction Timing Computation 78
- 3.6 SUMMARY 81 PROBLEMS 82 ENDNOTES 86

#### CHAPTER 4

19

44

68000 Software Considerations and Assembly Programming Applications

- 4.0 INTRODUCTION 88
- 4.1 ASSEMBLY LANGUAGE SOFTWARE AND PROGRAMMING TECHNIQUES 88 Assembler, Cross Assembler, Linker, and Loader Utilities 88 Writing Assembly Programs and Software Development 90 Programming and Software Engineering Considerations 96
- 4.2 DATA MOVEMENT, DATA-COMPARISON SOFTWARE, AND APPLICATIONS Software Considerations Software Considerations 99
- 4.3 DATA PROCESSING APPLICATIONS AND SOFTWARE CONSIDERATIONS Subtraction Operations Operations 104
- 4.4 SPECIAL INSTRUCTION GROUPS AND APPLICATIONS Multiple-Decision Instructions 108 Address, Stack, and Multiple-Movement Instructions
- 4.5 MACROS IN SOFTWARE DEVELOPMENT
- 4.6 SUMMARY 117 PROBLEMS 118
  - ENDNOTES 120

### CHAPTER 5

### 68000 Exception Processing Considerations

- 5.0 INTRODUCTION 122
- 5.1 GENERAL CONCEPTS OF EXCEPTION PROCESSING The Exception Vector Table and Exception Vectors

| N INSTRUCTION GROUPS | 64 |
|----------------------|----|
| 65                   |    |

73

96 Block Transfer Applications and 96 Data-Sequencing Applications and

101 Multiprecision Addition and 102 Multiplication and Division

#### 108

110 115

122 122

87

|            | Reset Exception Processing123General Scheme of Exception Processing125                                                                                                                                                                                                                   |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5.2        | INTERRUPT EXCEPTIONS AND APPLICATIONS128Interrupt Mask Levels128Autovector and User Vector Methods129                                                                                                                                                                                    |
| 5.3        | TRAP EXCEPTION PROCESSING AND APPLICATIONS132Using System Resources in the Supervisor Mode via Traps133Trap Software Routines and Applications133                                                                                                                                        |
| 5.4        | ERROR-RELATED EXCEPTIONS135Illegal Instruction, Unimplemented Instruction,<br>and Privilege-Violation Conditions136Uninitialized and Spurious Interrupt Exceptions137Zero-divide, CHK, and Trace Exception Conditions137Address and Bus Error Conditions138Double Bus Fault Condition142 |
| 5.5        | SUMMARY 142<br>PROBLEMS 143<br>ENDNOTES 147                                                                                                                                                                                                                                              |
|            | APTER 6<br>000 Hardware Considerations and Design Applications                                                                                                                                                                                                                           |
| 6.0<br>6.1 | INTRODUCTION14868000 HARDWARE SIGNALS AND FUNCTIONS149 Address,Data, and Asynchronous Buses for the 68000150 Function CodeOutputs151Other Buses and Signals152                                                                                                                           |
| 6.2        | MEMORY AND I/O INTERFACE SCHEMES156Memory-Device Types and Memory Concepts156Address Decoding, Strobing, and Memory Selection157Read and Write Timing Considerations157Timing Considerations of Asynchronous Inputs160                                                                   |
| 6.3        | MEMORY AND I/O SYSTEM DESIGN CONSIDERATIONS162The Memory Subsystem Design162Signal Buffering Considerations164                                                                                                                                                                           |
| 6.4        | CONTROL INTERFACE SCHEMES166Reset and Halt Interface166Timing Signals Associated with the 68000168Bus Error Considerations169                                                                                                                                                            |
| 6.5        | 68000-BASED BUSING SCHEMES 170<br>The VERSA Bus 170<br>The VME Bus 173                                                                                                                                                                                                                   |

- 6.6 SUMMARY 176
  - PROBLEMS 176
  - ENDNOTES 179

### CHAPTER 7

#### The 68000 Parallel Interface and Applications

- 7.0 INTRODUCTION 180
- 7.1 SYNCHRONOUS PARALLEL INTERFACE WITH THE 68000 6821 PIA (Peripheral Interface Adapter) Architecture 181 6821 PIA Synchronous Interface with the 68000 182 I/O Interface and Design Applications 183
- 7.2 THE 68230 PARALLEL INTERFACE AND TIMER (PI/T) Registers and I/O Ports 187 Interfacing the 68230 PI/T 189
- 7.3 DATA ENTRY AND DISPLAY SYSTEMS Keyboard and Hex Display Interface 192 System Hardware and Software Considerations 192 Other Forms of Keyboard and Interface Schemes 197
- 7.4 ELECTROMECHANICAL APPLICATIONS 198 Rotational and Linear Stepper Motors 199 Stepper-Motor Interface Considerations 199 Position Control Systems 203
- 7.5 SUMMARY 204 PROBLEMS 205 ENDNOTES 208

### CHAPTER 8

148

#### The 68000 Serial Interface and Applications

- 8.0 INTRODUCTION 209
- 8.1 SERIAL DATA COMMUNICATION CONCEPTS 210 8.2 6850 ACIA GENERAL ARCHITECTURE 212 Registers and I/O Ports 212
- 8.3 THE 6850 ACTA INTERFACE WITH THE 68000 AND APPLICATIONS 216 68000/6850 Interface Considerations 216 RS-232 Interface Application 218
- 8.4 68901 MFP (MULTIFUNCTION PERIPHERAL) GENERAL ARCHITECTURE 220 Internal Architecture of the MFP 221 Register Structure and Modes of Operation 221

181 187

192 The

Modes of Operation and Status Conditions of the ACIA 213

180

| 68000                       | 1 MFP INTERFACE WITH THE 68000 AND APPLICATIONS2270/68901 and I/O Interface Considerations227ed Data Communication System228                                                         |     | <b>10.3</b> MEMORY FAULT CORRECTION SCI<br>The instruction Restart Method 290<br>The Instruction Continuation Method                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PROF                        | IMARY 232<br>BLEMS 232<br>NOTES 234                                                                                                                                                  |     | The 68010/68012 Memory Fault Correc<br><b>10.4</b> BUS ERROR EXCEPTION PROCESS<br>WITH VIRTUAL MEMORY 293<br>Processing 293 Correction of Memory<br>Memory Schemes 297                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| The 6800                    | 00 Interrupt and DMA Interface and Applications                                                                                                                                      | 236 | 10.5 SUMMARY 301                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 9.1 INTE<br>Autov<br>Interr | RODUCTION236ERRUPT INTERFACE CONSIDERATIONS238ovectored and User-Vectored Interrupt Logic238rupt Controllers239rupt Expansion and the Daisy-Chain Mechanism240                       |     | PROBLEMS 302<br>ENDNOTES 305<br>CHAPTER 11<br>68020 and 68030 Architecture, Organ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 9.2 INTE<br>Interr          | rupt Expansion and the Daisy-Chain Mechanism240ERRUPT-DRIVEN SYSTEM APPLICATIONS242rupt-Driven Gain Controller242amic Random Access Memory (DRAM) Interface247                       |     | <ul><li>11.0 INTRODUCTION 306</li><li>11.1 GENERAL ARCHITECTURE OF THE Resources and Modified Resources of the sources of the</li></ul> |
| SY                          | INTERRUPT-DRIVEN DATA-ACQUISITION<br>YSTEM AND APPLICATIONS 253                                                                                                                      |     | Data, and Control Buses 309<br>Data Formats, Memory, and I/O Interfac<br><b>11.2</b> ADDITIONAL ADDRESSING MODE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Data-<br>9.4 DIRE<br>Gener  | A/D and D/A Interface253 A Typical-Acquisition System258ECT MEMORY ACCESS (DMA) CONSIDERATIONS260eral Architecture of the DMA Controllers26068440 and 68450 DMA Controllers263 Modes |     | FOR THE 68020 313 Memory Ind<br>Modes and Scaling 313 Bit-Field Ty<br>314 Packed and Unpacked BCD Instruct<br>Instructions and Enhancements 320                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| of Op<br>9.5 THE            | peration of the DMA Controllers 263<br>DMA INTERFACE AND APPLICATIONS 266                                                                                                            |     | <b>11.3</b> CACHE MEMORY CONCEPTS AND<br>68020 Cache Memory Organization and<br>Control and Cache Address Registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| DMA                         | A Sequence of Operations267A Channel Initialization269A Software Considerations270                                                                                                   |     | 11.4 GENERAL ARCHITECTURE OF THE<br>Instruction and Data Cache Memory Org                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| PROI                        | IMARY 272<br>BLEMS 274<br>NOTES 276                                                                                                                                                  |     | Additional Software Resources of the 68<br>Additional Hardware Resources of the 6<br><b>11.5</b> FUNCTIONAL IMPROVEMENTS OF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| CHAPTE                      | R 10                                                                                                                                                                                 | 070 | AND 68030 PROCESSORS 331<br>Capability 331 32-Bit Extended Inst                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                             | nd 68012 Architecture, Organization, and Applications<br>RODUCTION 278                                                                                                               | 278 | Memory and the Concept of Tag Field<br>Additional Signal Groups 332 . Soft<br>68020 and 68030 Processors 332                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Virtu                       | TUAL MEMORY AND VIRTUAL MACHINE CONCEPTS279ual Memory Schemes279ual Machine Schemes279                                                                                               |     | 11.6 SUMMARY 334<br>PROBLEMS 335                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 10.2 ARC<br>Addi            | CHITECTURE OF THE 68010 AND 68012 MICROPROCESSORS 28<br>itional Register and Busing Resources 284<br>itional Instructions and Modified Instructions 286                              | 34  | ENDNOTES 338                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

ON SCHEMES 290

thod 290 Correction Methods 291 OCESSING ASSOCIATED 293 Modified Bus Error (BERR) Exception Memory-Related Faults Using Virtual

#### Organization, and Applications

F THE 68020 307 Additional so of the 68020 307 Address,

Interface Schemes 310 MODES AND INSTRUCTIONS ory Indirection Addressing field Type of Instructions Instructions 316 Other

AND ORGANIZATION 320 on and Operation 320 Cache sters 322 F THE 68030 324 ory Organization 324 f the 68030 Processor 326 of the 68030 Processor 327 TS OF THE 68020 331 Memory Indirect Addressing ed Instructions 331 Cache Field 331 The 68020 and 68030 2 . Software Considerations for the

| APPENDIX A:                                                           | 339             |
|-----------------------------------------------------------------------|-----------------|
| Number Systems: Binary and BCD Operations                             | ∧ <sup>a</sup>  |
| APPENDIX B: ", , ", , 68000/10/12 Instruction Set and Condition Codes | q<<br>*«        |
| APPENDIX C: «,                                                        | 40              |
| Analog and Digital Converter Devices for Interface                    | wi              |
| APPENDIX D:                                                           | 42              |
| Instruction Timing for the 68000/10 Processors                        | 41              |
| GLOSSARY                                                              | <b>43</b><br>44 |
| INDEX                                                                 |                 |

q<n \*«\*

431 441

### **INTRODUCTION**

## **The Microprocessor Evolution**

It is no exaggeration to say that the microprocessor device has revolutionized digital electronics and the computer field. Most of the currently available digital, computer, and electronic systems use some form of microprocessor. With processing capability exceeding several million instructions per second (MIPS), the microprocessor is continuously finding new applications.

The earliest form of the microprocessor was a 4-bit device (4004). It was basically used as a 4-bit ALU (arithmetic logic unit) almost a quarter-century ago. The real microprocessor era started in the early 1970s, when Intel Corporation introduced the 8080 microprocessor. This was an 8-bit microprocessor, and contained an ALU and bus interface logic on board. It also had several 8-bit registers for storing operands and addresses. Although the unit required several power supplies and a power-sequencing scheme, it found extensive applications. The success of the 8080 microprocessor led other companies to get involved in the development of different forms of microprocessors.

Immediately after launching the 8080 processor, Intel began to improve its design. which resulted in the 8085. The 8085 processor is code compatible with the earlier 8080, but can operate on a single 5-volt power supply. Almost simultaneously. Motorola Corporation introduced the 8-bit 6800 microprocessor with nonmultiplexed data and address buses. The 6800 processor also incorporates the concept of double accumulators and has an index addressing scheme. The 6800 became an instant success. Several peripheral devices to interface with the 8085 and the 6800 processors were introduced into the market by a number of vendors.

During the mid-1970s, Commodore and Rockwell International introduced the 8bit 6502 microprocessor, which also became an instant success. This machine is similar

to the 6800 processor, but includes additional addressing capabilities such as memory indirect. The design of the Apple computer was based on the 6502 processor. At about the same time, Zilog Corporation introduced the 8-bit Z80 microprocessor. The Z80 is code compatible with the 8085 processor. It has additional resources with which to store data internally, and it also has the index addressing mode of the 6800 and 6502 processors. The Z80 processor found extensive applications in the 8-bit field, even though it entered the 8-bit market late.

Most of the processors we have mentioned were developed with NMOS technology. However ultralow power requirements dictated a processor using CMOS technology. RCA Corporation introduced the first CMOS 8-bit 1802 microprocessor for lowpower applications. Pacemakers and several other battery-powered devices use the 1802 type of processor. Most 8-bit processors have a 64-kilobyte address range.

Emerging applications soon demanded more processing power than 8-bit processors could provide. Intel corporation was again the leader in introducing the first 16-bit 8086 microprocessor in 1978. The internal architecture of the 8086 supports 16-bit operations. The external address bus can access 1 megabyte of memory, which was considered a great advantage. The 8086 has a 16-bit data bus. The 8088 processor is a scaled-down version of the 8086, with an 8-bit data bus. The IBM PC contributed to the great success of the 8086/88 processors.

To follow the 8086 processor, Motorola Corporation introduced the much more powerful and versatile 68000 microprocessor. It has a 16-bit data bus and an effective 24-bit address bus that can access 16 megabytes. The internal architecture of the 68000 is designed to support 8-bit, 16-bit, and 32-bit operations. There are several 32-bit data registers, each of which can be used as an accumulator. The architecture, linear address range, and versatile data-handling capability of the 68000 suited the needs of industry. Systems such as Apple's Macintosh further contributed to the popularity of the 68000 processor. During the same time frame, Zilog corporation introduced its 16-bit Z8000 processor, which is similar to the 68000 in terms of architecture.

Continuous demand by industry resulted in the development of even more powerful processors, such as the 68020 and 68030 in the 68000 family, and the 80386 in the 8086 family. The present trend of development will continue in the 1990s. In order to obtain more dedicated throughput, RISC (reduced instruction set computer chip) devices are becoming popular. But the demand for general-purpose processors will continue to rise.

Also observed in the microprocessor application market is the popularity of singlechip microcomputers and controllers, such as Intel's 8051 and Motorola's 68HC11. These 8-bit devices are suitable for 8-bit I/O interface applications. Sixteen-bit microcontroller devices are also becoming available.

All of the 8-, 16-, and 32-bit processors we have described are available in various packages using different processing techniques

# 16/32–Bit Microprocessors: 68000/68010/68020 Software, Hardware, and Design Applications

Objectives In this chapter we will study:

The 68000 family of microprocessors

Microcomputer configuration of the 68000 family.

Architectural features of the 68000.

Supervisor and user modes of operation

Special features, such as the queue and pipeline

## CHAPTER

# **The 68000 Family of Microprocessors** and Architecture

#### 1.0 INTRODUCTION

The 68000 microprocessor, introduced by Motorola Corporation in the late 1970s, is one of the most powerful and widely used 16/32-bit processors. It is the first member of the 68000 family of processors—a family that includes the 68008, 68010, 68012, 68020, and 68030 processor devices.

Microcomputer configurations based on these processors are similar. In addition, they all have the same basic architecture as that of the 68000. The architecture consists of internal registers and pointers and arithmetic logic and control units.

The 68000 operates in two distinct modes: the **supervisor mode** and the **user mode**. These two modes of operation maintain a relative separation between the operating system programs and the user programs.<sup>1</sup>

All processors obtain data from the memory block, perform the appropriate operations, and store the resulting data back in the memory. Processors in the 68000 family are structured to handle the **byte** (8-bit), **word** (16-bit), and **long-word** (32-bit) data elements.<sup>2</sup>

An understanding of the architecture, modes of operation, and data-handling schemes is essential to the study of the 68000 microprocessor and associated designs. It will also promote understanding of the other members of the 68000 family.

The material in this chapter will provide the necessary background to understand the software and system features of the 68000 processor. The hardware concepts and designs of the 68000 will be presented in later chapters.

#### 1.1 THE 68000 FAMILY OF MICROPROCESSORS

As mentioned previously, all processors in the 68000 family support byte, word, and long-word operations. We will now briefly introduce the important members of the 68000 family. Figure 1.1 illustrates the genealogy of these processors; they are developed using the VLSI (very-large-scale integration) MOS technology.<sup>3</sup>

#### The 68000 Microprocessor

The 68000 is the principal device of the 68000 family of microprocessors. The operating frequency of the 68000L4 is 4 MHz; for the 68000L12, the operating frequency is 12 MHz. Several other frequency versions are also available. The 68000 has a 16-bit data bus and an effective 24-bit address bus that supports 16 megabytes of address range. This microprocessor is normally contained in a 64-pin DIP (dual-in-line package), but it is also available in the 68-pin chip-carrier package.

#### The 68008 Microprocessor

The 68008 is the reduced-bus version of the 68000 processor. It has an 8-bit data bus and an effective 20-bit address bus that supports 1 megabyte of address range. The 68008 is contained in a 48-pin DIP. It is very cost effective in applications involving the standard 8-bit I/O (input/output) interface.



FIGURE 1.1 Genealogy of the 68000 family of microprocessors. (Courtesy of Motorola, Inc.)

#### The 68010 Microprocessor

The 68010 is the virtual memory microprocessor. It has all the resources of the 68000 microprocessor. In addition, it has extended internal resources to support the virtual memory management schemes. **Virtual memory** refers to a memory that is not physically present as a part of the system main memory, but is present as a part of the backup memory. This feature allows for error detection and possible error correction in memory access faults.

'I he 68010 is pin compatible with the 68000 microprocessor. The 68000 processor can he replaced with the 68010 in a system without any hardware changes. Additional software can then be written to support the virtual memory schemes.

#### The 68012 Microprocessor

The 68012 is the enhanced virtual memory microprocessor. It is architecturally identical to the 68010. It has an extended address bus that supports 2 gigabytes of address range, as well as additional control lines to support the multiprocessing activity. It is contained in an 84-pin grid-array package.

#### The 68020 Microprocessor

The 68020 is the cache memory microprocessor. In addition to all the resources of the 68010 microprocessor, it has internal resources to support cache memory operation. Cache memory is a fast-access memory that holds prefetched information; thus, it speeds up the system operation. The 68020 is truly a 32-bit microprocessor. It has a 32-bit data bus and a 32-bit address bus that support 4 gigabytes of address range. It also has additional control and interface lines to support the coprocessor interface. It is contained in a 114-pin grid-array package. The 68020 is considered to be one of the best 32-bit microprocessors, and it is one of the most widely used.

#### The 68030 Microprocessor

The 68030 is the enhanced version of the 68020 microprocessor. In addition to all the resources of the 68020, it has internal data cache memory and a memory management unit. These additional resources effectively enhance the throughput of the 68030 processor as compared to the 68020.<sup>4</sup>

#### The 68881 Coprocessor

The architecture of the 68881 coprocessor is different from that of other members of the 68000 family. The 68881 is capable of performing floating-point arithmetic operations to 80-bit precision. It can be interfaced to any member of the 68000 family of processors to increase the arithmetic processing power of the system.

The 68008 is the lowest member and the 68030 is the highest member of the 68000 family of processors. The gradation sequence is  $68008 \rightarrow 68000 \rightarrow 68010 \rightarrow 68012 \rightarrow 68020 \rightarrow 68030$ . These processors are upward code compatible. The software written for a lower level processor will work with a higher level processor. For example, the code written on a 68008-based system will work on a 68000-based system with a similar memory and I/O map. However, the reverse may not be true. Software written for a higher level processor, using the additional resources of that processor, will not work on a lower level processor. For example, the code written on a 68020-based system using the special resources of the 68020 will not work on a 68000-based system, which lacks those resources.<sup>5</sup>

The following example problem will review the concepts we have just discussed with regard to the 68000 family.

#### Example 1.1 The 68000 family of processors.

The 68008 and the 68000 processors support 32-bit internal operations. Their external data buses are 8 and 16 bits wide. Conceptually compute the relative speed of these two processors while transferring

- 1. byte-size data from memory into one of the internal registers of the processor;
- 2. word-size data from memory into one of the internal registers of the processor.

#### Solution

- 1. Byte (8-bit) transfers: The 68008 has an 8-bit data bus and transfers the byte-size data in one unit of time. The 68000 has a 16-bit data bus, out of which only 8 bits are used for byte transfers. Byte transfers, then, still take one unit of time.
- 2. Word (16-bit) transfers: The 68008 transfers a 16-bit word as two bytes. As such, it takes two units of time. By contrast, the 68000 transfers the complete word in one unit of time. Thus, for word transfers, the 68000 processor is twice as fast as the 68008 processor.

The memory and I/O (input/output) interface schemes are similar throughout the 68000 family of processors. This results in a well-structured microcomputer configuration, which we will now introduce.

# 1.2 TYPICAL MICROCOMPUTER CONFIGURATION OF THE 68000 FAMILY

Figure 1.2 illustrates the microcomputer configuration typical of the 68000 family. These microprocessors arc of the memory-mapped I/O type, in which the microprocessor communicates with an I/O device as if it were one of the memory locations. However, there are some special instructions in the 68000 family to efficiently deal with I/O data.

#### General Interface Scheme

Each member of the family has appropriate control and interface buses to support the synchronous and the asynchronous devices and systems, as shown in Figure 1.2. A bus is a group of signal lines. In the synchronous type of interface, data transfers take place upon certain clocking or timing events. The peripheral devices belonging to such earlier 8 bit processors as the 8085, 6800, and Z80 operate in this manner. In the asynchronous type of interface, data transfers take place via handshaking. In this protocol, the responding device provides an acknowledgment signal to the processor during data transfer... Most of the peripherals belonging to the 68000 family and the static memory follow this protocol."

There are also special interfaces. The interrupt mechanism is the traditional means by which to gain the attention of the processor by a slow I/O device. The DMA (direct memory access) is the traditional means by which to effect high-speed data transfers between the memory and I/O without the intervention of the microprocessor. I-icn member of the 68000 family supports both of these features explicitly. The system control interface consists of the reset, halt, and bus error detection functions. The other interlaces of the processor consist of the clock distribution network, system power distribution network, and the address decoding network. Details of all these functions will be discussed in later chapters.



FIGURE 1.2 Typical microcomputer configuration of the 68000 family of microprocessors. (Courtesy of Motorola, Inc.)

#### Typical 68000-Based Systems

The Macintosh from Apple Computers, Inc., the Amiga from Commodore, Inc., the ST from Atari, and the 9716 from Hewlett-Packard are some of the most popular microcomputer systems based on the 68000 microprocessor. The MEX68KECB microcomputer module from Motorola is an excellent 68000-based educational computer for learning the software and hardware features of the 68000 microprocessor and associated system designs.

An existing microcomputer system with a lower level processor can be upgraded to a higher performance processor with appropriate modifications. This is feasible because of the upward code compatibility.

The following example problem will review our discussion of the 68000-based system configuration.

#### *Example 1.2* 68000-based systems.

The 68000-based microcomputer is used in a control-system application. The processor is required to interface with the 8-bit I/O peripherals belonging to the earlier 6800 and Z80 type of processors. These devices respond to appropriate clocking events.

- 1. What is the preferred type of interface in the 68000? Why?
- 2. Suppose the 68000 system needs to be upgraded to the 68010. What additional hardware and software resources are required to accomplish this task?

#### Solution

- since these devices are of the synchronous type.

Existing software will function on the upgraded system. However, to make full use of the capabilities of the 68010, virtual memory software should be utilized.

The processing activity of a microprocessor depends on its architecture and how its internal resources are organized. The 68000 processor is rich in internal resources and has a 32-bit internal register architecture. We will now introduce these important concepts.

#### **1.3 GENERAL ARCHITECTURE OF THE** 68000 MICROPROCESSOR

The architecture of the 68000 microprocessor serves as the prototype on which all the other processors in the family are based. Figure 1.3 illustrates this internal architecture. It includes the following features:

> eight 32-bit data seven 32-bit ad two 32-bit stack user stack supervisor one 32-bit progr

one 16-bit status

In addition, the 68000 contains a 32-bit arithmetic logic unit (ALU), an instruction decoding unit, a control unit, a bus interface unit, and an execution unit. For the sake of simplicity, these resources are not indicated in the figure. For the 32-bit registers and the data structures, the byte corresponds to the lower 8 bits, the word corresponds to the lower l6 bits, and the long word corresponds to all of the 32 bits. We will now provide a functional description of the basic features.

#### Data Registers D0-D7 (Dn)

These eight data registers are for general-purpose data storage and processing. They handle bytes (8 bits), words (16 bits), and long words (32 bits) of data. Each of these registers can function as an accumulator. An **accumulator** is a special register that provides data operands to the ALU and stores the result from the ALU. In addition, any of

1. Interfacing the 6800 and Z80 peripherals: Synchronous interface is preferred,

2. Upgrading to the 68010: No additional hardware is required. However, to make full use of the capabilities of the 68010, memory management units may be added.

| a registers, D0-D7         | (Dn)  |
|----------------------------|-------|
| ddress registers, A0-A6    | (An)  |
| k pointers:<br>pointer, A7 | (USP) |
| y stack pointer, A7'       | (SSP) |
| ram counter                | (PC)  |
| s register                 | (SR)  |



FIGURE 1.3 The internal architecture of the 68000. (Courtesy of Motorola, Inc.)

the data registers can be used for memory indexing, a process in which a number in the data register is added to the base address to obtain the effective address of the data operand. Operations on the data register operands affect the flag bits in the status register.

### Address Registers A0-A6 (An)

These seven address registers function as address **pointers.** They store and operate on word- and long-word address operands. By means of these address operands, memory can be accessed. The address registers also can be used for general-purpose storage of operands of word and long-word size, as well as for memory indexing. The address registers do not support the byte operands. Operations on the address register operands will not affect the flag bits in the status register (except in compare-type operations).

### Stack Pointers A7 (USP) and A7' (SSP)

As previously mentioned, the 68000 microprocessor operates in two distinct modes called the user mode and the supervisor mode. The former deals with user programs; the latter, with system-level programs. In order to maintain a distinction between these modes, the 68000 has two 32-bit stack pointers: the **user stack pointer (USP** or A7)

and the supervisor stack pointer (SSP or A7')- The 68000 can operate in only one of the modes at any given time. Either the USP or the SSP controls the system stack, depending on the mode of operation. The stack pointers can be initialized to locate the stack anywhere within the available memory space of 16 megabytes for the 68000 microprocessor. They should be initialized at the even word boundaries.

#### Program Counter (PC)

This 32-bit register keeps track of program space and sequentially obtains the instructions and associated operands from program space. Program space is that section of memory containing the program code.

Only the lower 24 bits of the program counter are brought out as the effective address bus for the 68000. This provides an address range of 16 megabytes ( $2^{24} = 16$  megabytes) or 8 megawords (1 word = 2 bytes). The PC operates on an even word boundary. It advances to the next sequential program location after fetching the current instruction.

#### Status Register (SR) and Flag Structure

Decision making in the 68000 is dependent upon the flag bits. These flag bits are contained in the status register. Figure 1.4 illustrates the details of the 16-bit status register. It is divided into two bytes—a lower byte, called the user byte or the condition code register (CCR), and an upper byte, called the system byte.

User Byte This byte contains the following five flag bits:

| C (Carry flag):    | Set to 1 for arithmetic or logical overflow.                                                   |
|--------------------|------------------------------------------------------------------------------------------------|
| V (Overflow flag): | Set to 1 for overflow in twos-complement operations.                                           |
| Z (Zero flag):     | Set to 1 if the result of the previous operation is zero.                                      |
| N (Negative flag): | Set to 1 if the most significant bit (MSB) of the operand is 1 (signifying a negative number). |
| X (Extend flag):   | Similar to the carry flag, but not affected in the data movement operations.                   |

When these flags are not set to the 1 condition, they remain in the 0 or reset condition. Certain instructions may not affect these flags. The details of these variations will be discussed when the instruction set is considered in the next chapter.

*SYSTEM Byte* This is the upper byte of the status register containing the following status information relating to the supervisor mode of operation:<sup>8</sup>

| I2-I1, and I0 (Interrupt mask bits): | ret to the required interrupt mask level.   |
|--------------------------------------|---------------------------------------------|
|                                      | Interrupts above this level are recognized. |
|                                      | Can specify up to eight levels.             |





| S (Supervisor bit): | S = 0 (system in user mode).       |
|---------------------|------------------------------------|
|                     | S = 1 (system in supervisor mode). |
| T (Trace bit):      | T = 0 (system in run mode).        |
|                     | T = 1 (system in trace mode).      |

The trace condition is set and used for software debugging. The system level operation is guided by the condition of the system byte. We will learn more about this byte in subsequent sections of this chapter.

It is convenient to refer to numbers in the **hex format**, especially when dealing with data and address operands. In the hex format, the decimal numbers 0-9 are represented similarly. The decimal numbers 10, 11, 12, 13, 14, and 15 are represented by the alphabetical symbols A, B, C, D, E, and F. In this book the \$ sign is used to represent the hex digits. Each hex digit takes four bits; for example, \$F corresponds to decimal 15 and binary 1111. The arithmetic operations in the hex format are performed to the base 16. Appendix A provides information about the hex and other number systems.<sup>9</sup>

The following example problem will review our discussion of the architecture of the 68000 processor.

#### Example 1.3 Architecture and flags of the 68000.

The initial values of the registers DO, Dl, A0, Al, USP, SSP, and the SR are as shown (in the hex format).

| D0 = \$ 0 0 1 | 23456  | $\mathbf{D1} = \$ \mathbf{A} \mathbf{A} \mathbf{B} \mathbf{B} \mathbf{C} \mathbf{C} \mathbf{D} \mathbf{D}$ |
|---------------|--------|------------------------------------------------------------------------------------------------------------|
| A0 = \$ 0 0 6 | 54321  | A1 = \$ 0 0 0 A 5 C 0 7                                                                                    |
| SR =          | \$0400 |                                                                                                            |

- 1. The word operand from DO is added to the corresponding word operand from Dl, with the result in Dl (ADD.W D0,D1 instruction). Show the contents of DO, Dl, and SR after the addition. Take into account that the ADD instruction affects the flags.
- 2. The long words in A0 and Al are added to each other, with the result in A0 (ADDA.L A1,A0 instruction). Show the contents of A0, Al, and SR after the addition. Use the same initial values.

#### Solution

**1. Addition of the word operands in DO and Dl:** The word operands consist of the lower four hex digits of the register contents. The hex addition is as follows:

| Hex word in $D0 = $ \$ | 3456    |
|------------------------|---------|
| Hex word in $DI = $    | CCDD    |
| Hex addition $= 1$     | 0 1 3 3 |

There is an overflow from the fourth hex digit, which wiil set the carry flag and the extend flag. The word result \$ 0 1 3 3 will be transferred to the lower word position of the DI register. The upper word of DI and the register DO are not affected. Expanding the result:

it can be seen that

48. j

| the MSB $= 0;$                  | as such, the N flag = $0$ |
|---------------------------------|---------------------------|
| the result is nonzero;          | as such, the Z flag = $0$ |
| no twos-complement<br>overflow; | as such, the V flag = $0$ |
| arithmetic overflow;            | as such, the C flag = $1$ |
|                                 | the X flag = $1$          |

Thus, the user byte of the SR contains

$$- - - X N Z V C$$

$$0 0 0 1 0 0 0 1 = $11$$

and the system byte is not affected:

$$T - S - - I2 I1 I0$$
  
0 0 0 0 0 1 0 0 = \$04

The final results are

$$D0 = \$ 0 0 1 2 3 4 5 6$$
  

$$D1 = \$ A A B B 0 1 3 3$$
  

$$SR = \$ 0 4 1 1$$

2. Long-word addition of A0 and A1: Following the same hex addition principles,

The long-word operand in A0 = 00654321The long-word operand in A1 = 000A5C07The long-word result = 0006F9F28

This long-word result gets transferred to register A0. Register A1 is not affected. The SR also is not affected, since the operation is on the address registers, and operations on address registers do not affect flag bits.

The final results are

$$A0 = $006F9F28$$

$$A1 = $000A5C07$$

$$SR = $0400$$

The processor examines the flag bits in the status register and controls the program flow accordingly. We will study more about this program flow in later chapters on software.

#### Other Resources

Other resources, such as the ALU, the instruction decoder, the execution unit, the bus interface unit, and the control unit are also important. The 68000 uses these resources very efficiently. They are internal to the processor and cannot be externally accessed. Their functions are as follows:

*The ALU* This arithmetic logic unit performs the arithmetic and logical operations on data operands. The size of these operands may be byte, word, or long word. The flag bits in the user byte of the status register are affected as a result of ALU operations.

*Instruction Decoder* This unit decodes instructions and sets up internal conditions for the execution unit.

*Execution Unit* This unit performs actual operations within the processor, such as data movement.

**Bus Interface Unit** This unit drives the address bus with appropriate effective address and handles data transfers on the data bus. It also generates and monitors the bus control signals necessary for the successful data transfers.

*Control Unit* This unit generates appropriate control and timing signals within the processor and coordinates all processor operations.

#### Supervisor and User Modes of Operation

All of the processor and system resources and all the instructions are available in the supervisor mode, but some cannot be used in the user mode of programming. This condition provides a safety mechanism in that the user cannot inadvertently modify or corrupt the system-level programs and resources. The operating system software is in the supervisor mode. These modes of operation are conceptually shown in Figure 1.5.

*Supervisor Mode* (S=1) This is the highest level or mode of operation. In this mode, the 68000 processor services system-level tasks, such as reset functions, interrupts, traps, tracing, and error conditions. This type of activity is known as **exception processing**. On the power-up reset condition, the S bit in the system byte of the status register is set to 1 and the 68000 enters the supervisor mode, upon which it executes the **reset routine**. This routine is always a system-initialization program. SSP is the effective stack pointer in the supervisor mode.



#### MC68000-USER/SUPERVISOR MODES

Transition may occur only during exception processing





At the end of the reset exception routine, the processor may clear the S bit in the system byte to 0. This puts the processor in the user mode.

*User Mode* (*S=0*) This is the lower level of operation. It is for this level that users write their normal programs. As we already know, some resources and instructions are not functional in this mode of operation. Any attempt to use these resources in the user mode results in an error condition whereby control is transferred to the supervisor mode. This error condition is known as a **privilege violation.** USP is the effective system stack pointer in the user mode.

Figure 1.5 illustrates the intercommunication between the two modes of operation. Exception conditions, such as reset, interrupts, errors, traps, and trace, will set the S bit in the status register to 1 and move the processor into the supervisor mode. **Traps** are special software instructions that can be used in the user mode in order to move to the supervisor mode.

The processor moves from the supervisor mode into the user mode if the S bit in the system byte is cleared to 0. This is accomplished by executing such software instructions as the RTE (return from exception), MOVE to SR (move data to status register), and others. These instructions are privileged; they can only be used in the supervisor mode.

The following example problem will review our discussion of the supervisor and user modes of operation.

**Example 1.4** Supervisor and user modes in the 68000. The initial values of the USP, SSP, and SR are as follows:

$$USP = \$ 0 0 0 0 4 8 0 C \qquad SSP = \$ 0 0 0 0 3 7 A 0$$
  
SR = \$2400

----

1. Is the processor operating in the user mode or in the supervisor mode? Why?

2. Where is the system stack located?

Solution

1. Processor operating mode: The processor is operating in the supervisor mode, since the S bit in the system byte is 1. Expanding the system byte of the SR:

$$\$ 2 4 = \$ 0 0 1 0 0 1 0 0$$
  
T S I2 I1 I0

it can be seen that the S bit is set to 1.

2. System stack: Because the processor is in the supervisor mode, SSP controls the system stack. As such, the system stack is located at \$ 0 0 0 0 3 7 A 0.

#### 1.4 OTHER FEATURES OF THE 68000 FAMILY OF PROCESSORS

The primary objectives in using the 16/32-bit processor are to obtain more processing power and more speed. In the 68000 family, these objectives are achieved by means of the **prefetch-queue** and the **instruction-pipe** architectures.<sup>10</sup>

#### The Prefetch Queue

When the processor is internally busy with operations on data corresponding to the current instruction, the external data and address buses are relatively free. The bus unit within the microprocessor uses these buses to obtain the next instruction code from memory. This is known as **prefetching.** The internal register bank where this code is stored has memory in the form of FIFO (first in first out) and is known as the **queue.** The prefetch-queue mechanism overlaps processor activity and thus enhances speed. All members of the 68000 family have a two-word prefetch queue.

#### The Instruction Pipeline

The control unit within the processor sequentially arranges decoded instructions and associated operands in the form of a pipeline. The execution unit within the processor obtains information from this pipe for its operation. The pipe is structured along FIFO lines.

The internal pipeline can be formed by the control unit when the execution unit is busy with the previous operation. Thus, there is an overlap of processor activity which enhances the speed of operation. The 68020 and 68030 processors have a three-word pipe.

#### 1.5 SUMMARY

In this chapter we introduced the 68000 family and outlined the relative features of these processors. Motorola entered the 16-bit market in the late 1970s with the 68000.

The 68000 microprocessor has an effective 24-bit address bus and a 16-bit data bus; it supports a 16-megabyte address range. The 68000 is normally contained in a 64-pin DIP package and is also available in a 68-pin grid-array package.

The 68008 is a reduced-bus version of the 68000 processor. It has an effective 20bit address bus and an 8-bit data bus; it supports a 1-megabyte address range. It is contained in a 48-pin DIP package.

The 68010 is a virtual memory microprocessor. It contains all the resources of the 68000 and is also pin compatible with the 68000. In addition, the 68010 processor has extended internal resources to support virtual memory schemes. The 68012 processor is an enhanced version of the 68010 processor with an effective 31-bit address bus that supports 2 gigabytes of address range. The 68012 is contained in an 84-pin grid-array package.

The 68020 is a 32-bit processor with all the resources of the 68012. The address and the data buses are extended to 32 bits. It supports a 4-gigabyte address range. In addition, the 68020 processor has internal instruction cache memory and the resources to support it. The cache memory holds most recently fetched instructions and supplies them to the processor. This speeds up the system operation.

The 68030 is an enhanced version of the 68020 processor with all the resources of the 68020. In addition, it has internal data cache memory and a memory management unit, further enhancing the throughput of the 68030 as compared to the 68020 processor.

The performance gradation sequence is 68008 - 68010 - 68010 - 68012 -68020 -> 68030. The 68008 is the lowest member of the family and the 68030 is the highest. These processors are upward code compatible.

Processors in the 68000 family are provided with proper control and interface buses to support synchronous and asynchronous devices. Moreover, the interrupt and the DMA operations are fully supported.

The architecture of the 68000 microprocessor forms the basis for that of all the other members of the family. It consists of eight 32-bit data registers, seven 32-bit address registers, one 32-bit program counter, two 32-bit stack pointers, one 16-bit status register, and a 32-bit ALU. The 68000 operates in two distinct modes: the supervisor mode and the user mode. This feature serves to maintain separation between the operating system programs and the user programs.

Each member of the 68000 family has a two-word prefetch queue, which effectively speeds up processor operation. In addition, there is a three-word pipeline in the 68020 and 68030 processors, speeding up processor operation still further.

#### PROBLEMS

- 1.1 What are the physical address spaces for
  - (a) the 68008 and 68000 processors;
  - (b) the 68010 and 68012 processors;
  - (c) the 68020 and 68030 processors.
  - Specify these address spaces in bytes and words.
- 1.2 Does software written on a 68000-based system work with a 68020-based system having the same memory and I/O map? What happens if the memory and I/O maps are different?
- 1.3 Specify special conditions that would enable software written on a higher processor, such as 68010, to function on a lower processor, such as 68008.
- 1.4 Compute the relative speed of the processors in question in the following situations:
  - (a) the 68008 and 68000 transferring long words from memory into the processor internal registers:
  - (b) the 68008 and 68000 transferring long words from the processor internal registers into memory
- 1.5 Compute the relative speed of the processors in question in the following situations:

- registers;
- synchronous and asynchronous buses? Why or why not?
- 1.7 Describe two or more advantages and disadvantages of using synchronous and asynchronous interfaces.
- to make the scaled-down version functional,
  - (a) what hardware modifications are necessary? (b) what software modifications are necessary?
- processors.
- why not?
- **1.11** The initial values of the registers in a 68000 register are

D0 =\$01020. A0 = \$00135USP = \$ 0 0 0 0 4SR =

- (a) long word in DO added to long word in Dl, with the result in Dl; (b) byte in DO added to byte in Dl, with the result in DO; (c) long word from Al transferred into A0.
- 1.12 Using the initial conditions given in Problem 1.11, state the contents of the affected registers after each of the following operations:
  - (a) long word from DI transferred into Al;
  - (c) operation (b) repeated, with the result in A0.
- **1.13** With the initial conditions as stated in Problem 1.11, (a) is the processor in the user mode or the supervisor mode? Why?
- 1.14 How do the user and the supervisor modes differ?
- **1.16** Repeat Problem 1.15 under the following conditions:
  - (a) byte result \$00 in D6 register; (b) long-word result \$0123456B in Al register.

(a) the 68000 and 68010 transferring words from memory into the processor internal

(b) the 68000 and 68010 transferring words internally from one register into the other.

1.6 Is it possible for the processor to simultaneously address the devices connected to the

1.8 Suppose you are required to scale down a 68000-based system to that of a 68008. In order

1.9 List three differences between the data and the address registers in the 68000 family of

**1.10** Can the USP and the SSP be used simultaneously as stack pointers? Why or why not? Can both the stack pointers be initialized at the same location to refer to the stack? Why or

| 20304  | = 10  | <b>\$</b> A 0 B 0 C 0 D 0 |
|--------|-------|---------------------------|
| 35798  | A1 =  | \$00A97532                |
| 040A0  | SSP = | \$0000340A                |
| \$0304 |       |                           |

State the contents of DO, DI, A0, Al, and the SR after each of the following operations:

(b) long word in A0 added to long word in Dl, with the result in Dl;

(b) can the processor use all the instructions, given your response to (a)? Why or why not?

**1.15** The user byte of the SR is \$00 initially and the interrupt mask level is set at 6. The processor is operating in the supervisor mode. The last addition operation has resulted in a word operand \$FE00 in data register D7. What are the contents of the status register?

- 1.17 Specify what happens under the following conditions:
  - (a) byte operand addressed in AO;
  - (b) stack located at an odd boundary, such as \$00003401;
  - (c) memory reference I2345678A made by the 68000.

### ENDNOTES

- 1. Motorola, Inc. M68000 16/32 Bit Microprocessor Programmer's Reference Manual, Fifth Edition. Englewood Cliffs, NJ: Prentice-Hall, 1987.
- 2. Motorola, Inc. MC68000, MC68008, MC68010112 Data Books. Phoenix, AZ: Motorola Technical Operations, 1983.
- 3. Motorola, Inc. The M68000 Family. BR 176, Rev. 2. Phoenix, AZ: Motorola Technical Operations, 1986.
- 4. Reinhort, J. Extra Functions-32-Bit Processors. Boston: Electronic Products, 1986.
- 5. Motorola, Inc. MC68020 Benchmark Report. BR322. Phoenix, AZ: Motorola Technical Operations, 1986.
- 6. Motorola, Inc. The M68000 Family. BR176, Rev. 2. Phoenix, AZ: Motorola Technical Operations, 1986.
- 7. Subbarao, W. Microprocessors: Hardware, Software, and Design Applications. Englewood Cliffs, NJ: Prentice-Hall, 1984.
- 8. Stranes, T. "Design Philosophy Behind the M68000." Byte (Apr., May, Jun. 1983).
- 9. Gibson, M., and Liu, C. Microcomputers for Scientists and Engineers. Englewood Cliffs, NJ: Prentice-Hall, 1987.
- 10. Motorola, Inc. MTT20: 68020 Course Notes. Phoenix, AZ: Motorola Technical Operations, 1987.

# **The 68000 Memory Organization** Schemes, Data Structures, and **Addressing Modes**

#### Objectives

In this chapter we will study:

Memory organization and selection schemes for the 68000 Data structures and representation for the 68000 Stack memory organization and structure for the 68000 Instruction format and structure for the 68000 Addressing modes for the 68000

## **CHAPTER**

#### 2.0 INTRODUCTION

Memory access is an integral part of any computer system operation. For the 68000, memory is organized as blocks of even and odd bytes. Data are structured so that bytes can be accessed individually, words can be accessed as two bytes, and long words can be accessed as two words. This provides an efficient and reliable memory access for data operands of varying size.

The stack memory is word-aligned. The program memory, where instructions and associated operands reside, is similarly word-aligned. Thus, the complete 16-bit data bus of the 68000 is utilized, optimizing the stack and instruction fetch operations.

The 68000 processor has 14 different addressing modes with which to access memory. Depending upon the application, any of these addressing modes can be used.

An understanding of memory organization schemes and data structures is essential to the study of the addressing modes. We must first learn about these addressing modes to understand the instructions, software features, and programming techniques of the 68000, all of which will be introduced in the next chapter. Note that throughout the book, the overbar is used to represent an active low signal. For example, /LDS means that the signal LDS is active when it is at the low logic level and is inactive when it is at the high logic level.

# 2.1 MEMORY ORGANIZATION SCHEMES AND DATA STRUCTURES

The 68000 microprocessor handles the byte, word, and long words of data. The memory is organized as 16-bit words and supports the aforementioned data elements.

#### Memory Organization and Selection Schemes

Figure 2.1 illustrates the memory organization and selection schemes for the 68000. The memory is structured as blocks of even and odd bytes. It can be accessed as bytes, words, or long words with the help of two strobes: /LDS and /UDS. These are active low signals.

**/LDS** is called the **lower data strobe.** When it is active, the lower or the odd memory byte is selected. **/UDS** is called the **upper data strobe.** When it is active, the upper or the even memory byte is selected. When both strobes are active, both bytes are selected, providing a word access.

The odd byte is connected to the lower eight data bits, D0-D7, of the data bus. The even byte is connected to the upper eight data bits, D8-D15, of the data bus.

The 23 address lines, A1-A23, of the address bus provide an effective address range of eight megawords. The conventional A0 address line is brought out in the 68000 as the /LDS and the /UDS strobes. When they are active individually, these two strobes select either an odd byte or even byte. This provides an effective address range of 16 megabytes. An R/W signal from the processor is the **read/write strobe**. If this R/W strobe is at a high logic level, the processor reads the data from the memory. By the

FIGURE 2.1 (a) Memory organization and (b) selection schemes for the 68000.



| ŪDŠ  | LDS                                    | Memory selected             |
|------|----------------------------------------|-----------------------------|
| High | High                                   | None                        |
| High | Low                                    | Lower or odd byte selected  |
| Low  | High                                   | Upper or even byte selected |
| Low  | Low                                    | Both bytes selected (word)  |
|      | · ···································· | (b)                         |

same token, if this signal is at a low logic level, the processor writes the data into the memory. Details of these signals will be discussed when we deal with the hardware aspects of the 68000.

#### Data Structures and Representation

*Bytes, Words, and Long Words* Figure 2.2 illustrates how data are represented in the memory. The bytes can be accessed at the even or at the odd address boundaries. The word, consisting of two bytes, should be accessed only at the even address boundary. Similarly, the long word, consisting of two words, should be accessed only at the even address boundary. The word at the lower address corresponds to the higher word element of the long word. Word or long-word access at an odd boundary results in an error condition called the **address error.** This error condition transfers control to the supervisor mode and the operating system programs.<sup>112</sup>

**BCD** (*Binary Coded Decimal*) The decimal numbers are represented in the BCD (binary coded decimal) format. Each BCD digit is a 4-bit element. Two BCD digits are contained in a byte. For a BCD string, the first BCD digit at the lowest address corresponds to the **MSD** (most significant digit).

(a)

(b)



The data structures for the 68010 and 68012 processors are similar to those for the 68000. For the 68008, which has only an 8-bit data bus, the memory is byte organized. The /LDS and the /UDS are integrated into a single data strobe, /DS. A word is accessed as two sequential bytes for the 68008.<sup>3</sup>

The following example problem will review our discussion of data structures.

#### Example 2.1 Data structures for the 68000. Suppose that we are required to store the following:

For the BCD data, the leading zero is introduced by the processor, since the memory cannot be accessed at 4-bit boundaries.<sup>4</sup>

- 2. Long word from \$0040E0: The long word from location \$0040E0 will be MSD LSD T I
  - \$7F4ECAD8.
- 68008 processor. The memory is byte organized. A word occupies two byte locations.

data bytes \$7F and \$4E at locations \$0040E0 and \$0040E1; data word \$CAD8 at location \$0040E2; long data word \$2468A840 at the next location: BCD data string 1234567 starting at the next location.

Even memory

address

\$0040E0

\$0040E2

\$0040E4

\$0040E8

\$0040EA

- 1. Indicate the contents of the memory for the 68000 processor.
- 2. What will be the contents of a long word read from location \$0040E0?
- 3. Repeat (1) and (2) for the 68008 processor.
- 1. Memory contents: Figure 2.3(a) indicates the contents of the memory for the 68000 processor. The memory is word organized. The long word occupies two word positions, starting at \$0040E4. In the long word \$2468A840, the first digit, 2, is the MSD and the last digit, 0, is the LSD.

|     |        |     |        | Odd memory<br>address | Data<br>type |
|-----|--------|-----|--------|-----------------------|--------------|
| Eve | n byte | Ode | i byte |                       |              |
| 7   | F      | 4   | E      | \$0040E1              | Byte         |
| с   | A      | D   | 8      |                       | Word         |
| 2   | 4      | 6   | 8      | 1                     | Long         |
|     | 8      | 4   | 0      |                       | word         |
| 0   | 1      | 2   | 3      | \$0040E9              | BCD          |
| 4   | 5      | 6   | 7      | \$0040EB              |              |
|     | (8     | ı)  |        |                       |              |

**3.** 68008 memory organization: Figure 2.3(b) shows the corresponding results for the



The 68000 processor uses memory-mapped I/O in which the processor considers memory and I/O to be similar to one another. The memory organization for the 68000 family is linear, allowing for access of any memory location without readjusting the address mechanism. This simplifies the stack and queue operations, which will now be introduced.

#### Stack and Queue Organization and Structure for the 68000

A stack is a LIFO (last-in-first-out) data structure in the memory. Some of the internal registers of the processor are saved automatically on the stack whenever there is a change in program flow due to subroutines or exceptions. The system stack pointer (SP) controls the stack operation. The stack pointer is either SSP (A7) or USP (A7), depending upon the mode of operation. The program counter is saved on the active system stack on subroutine calls and is restored from the stack on the returns. On the other hand, both the program counter and the status register are saved on the supervisor stack during the processing of exceptions, such as interrupts and traps. They are restored on return. The system stack fills from high memory to low memory.<sup>5</sup>

The stack is always word organized and word aligned. Byte data are put on the stack in pairs, preserving the word alignment of the stack. Saving information on the stack is known as **pushing**. Retrieving the information from the stack is known as **popping** or **pulling**. The stack pointer (SP) always points to the top of the stack, where the last element has been pushed. The SP predecrements by two for pushing a new word onto the stack. Similarly, the SP postincrements by two after pulling a word element from the stack. For long-word pushing or pulling, the SP is predecremented or postincremented by four.<sup>6</sup> The stack should always be accessed at even boundaries.

A queue is a FIFO (first-in-first-out) data structure in the memory. A queue may be implemented to fill in from high memory to low memory, or vice versa. Queues may be byte or word organized. They are very helpful in setting up memory tables and strings. There can be several queues set up in the memory. The stack and queue are very important data structures and are explicitly supported by the addressing modes of the 68000.

The following example problem on the stack and queue will promote better understanding of these structures.

#### Example 2.2 Stack and queue structures. The initial values of the USP, SSP, A0, and A1 are as follows:

USP = \$0000480CA0 =\$0000 B D 0 4

The 68000 is executing a main user program in the user mode and the JSR (jump to subroutine) instruction has been encountered. The next instruction to be executed in the main program is at PC location \$00024A08.

- 1. Indicate the contents of the stack.
- alize the queue structure. How many words are contained in the queue?

#### Solution

- \$0000BDO4) + 1] = \$15 word elements.

### SSP = \$ 0 0 0 0 3 7 A 0A1 = \$0000BD18

2. The subroutine sets up a memory table in the form of a word-organized queue. AO points to the first clement and Al points to the last element in the queue. Conceptu-

**1.** Stack: Figure 2.4(a) shows the contents of the stack. USP is the system stack pointer, since the processor is in the user mode. The USP gets predecremented by four and the PC pointing to the next instruction in the main program gets pushed onto the stack. **2.** Queue: Figure 2.4(b) shows the conceptual queue structure. It contains [(\$0000BD18



The **RTS** (return-from-subroutine) instruction restores the stored contents from the stack. RTS is the last instruction in any subroutine. On executing the RTS instruction in the subroutine of Example 2.2, the contents of the stored PC (\$00024A08) are pulled from the stack and restored into the PC. This causes the main program to resume, starting at \$00024A08. This is the location of the next instruction to be executed in the main program, while the subroutine is called. The SP is incremented to its original value: \$0000480C.

A subroutine called by another subroutine is said to be **nested.** Suppose the first subroutine calls a second subroutine. The PC pointing to the next instruction to be executed in the first subroutine is stored on the stack, on top of the earlier stored PC (corresponding to the main routine). The processor then executes the second subroutine. At the end of the second subroutine, the RTS instruction is executed. This restores the PC corresponding to the first subroutine from the stack. At the end of the first subroutine, another RTS instruction is executed. This restores the PC corresponding to the main program from the stack. Ultimately, the SP is incremented to its original value. The available stack space determines how many of the subroutines can be nested. A similar mechanism works for nesting exceptions such as interrupts.<sup>7</sup>

### 2.2 INSTRUCTION FORMAT AND STRUCTURE

A software program consists of a sequence of instructions. These instructions are stored in program memory in the form of machine code. The **program memory** is that area in memory addressed by the program counter. The program memory is word aligned for the 68000.

#### Instruction Format

For the 68000, instructions are from one to five words, as shown in Figure 2.5. The first word, which is called the **operation word (op. word)** specifies the length of the instruction and the type of operation to be performed. The remaining words specify the appropriate source and destination operands. The processor obtains the source operand, performs the specified operation, and puts the result at the destination. Instructions for the 68000 have a well-defined structure enabling programmers to clearly identify the source and destination operands without ambiguity.



#### Instruction Structure

An instruction may be of the single- or the double-operand type. For the **single-operand** type, the specified operand is always the destination. For the **double-operand** type, the first operand is the source operand and the second is the destination. We will define and use three instructions for our discussion in this chapter. These instructions reference an effective address <ea> and are as follows:

| CLR <ea></ea>            | Clear the contents of the specified address.                                               |
|--------------------------|--------------------------------------------------------------------------------------------|
| ADD <ea>,Dn</ea>         | Add the contents of the effective address to the specified data register Dn ( $n = 1-7$ ). |
| MOVE <ea>,<ea></ea></ea> | Move the contents of the source effective address to the destination effective address.    |

The CLR instruction is of the single-operand type; the other two are of the doubleoperand type. Figure 2.6 illustrates typical instruction structures for the 68000 processor with single and double operands. Most of the instructions are similarly structured. Also, in most cases, the data size is explicitly specified to be byte, word, or long word, as shown; thus, the same mnemonic statement may be used for different types of data.<sup>8</sup>

Clearly, the effective address is an integral part of the instruction. In that the 68000 has 14 distinct addressing modes to specify the effective address, it is a very powerful and versatile processor. Some of these modes deal with the register reference, some deal with the memory reference, and some deal with the control.



#### 2.3 REGISTER DIRECT AND REGISTER INDIRECT ADDRESSING MODES

Motorola Corporation introduced a notation scheme to refer to the registers and operands in dealing with the addressing modes and the instructions. We will follow this notation, which is given in Figure 2.7.

| Г |           |                                                                              |
|---|-----------|------------------------------------------------------------------------------|
| İ | Dn        | Data register (n specifies the register number)                              |
| ļ | An        | Address register (n specifies the register number)                           |
| ŀ | Rn        | Dn or An (n specifies the register number)                                   |
| ļ | PC        | Program counter                                                              |
|   | SR        | Status register                                                              |
| I | CCR       | Condition code register (user byte of the SR)                                |
| 1 | SSP       | Supervisor stack pointer                                                     |
| I | USP       | User stack pointer                                                           |
| ł | SP        | Active system stack pointer (either SSP or USP)                              |
| İ | d8        | 8-bit displacement value                                                     |
| ļ | d16       | 16-bit displacement value                                                    |
|   | N         | Operand size in bytes (N = 1, 2, or 4 for byte, word, or long-word operands) |
|   | (An)      | Contents of the location addressed by An                                     |
|   | <ea></ea> | Effective address of the operand                                             |
| 1 |           |                                                                              |

FIGURE 2.7 Motorola's register and operand notation for the 68000 addressing modes and instructions.

In the register direct addressing modes, either the data or the address registers hold the data operands. On the other hand, in the register indirect addressing modes, one of the address registers holds the base address of the data operand. The register-related addressing modes are indicated in Figure 2.8.

| Addressing Mode                                                    | Syntax   | Effective Address <ea></ea>                         |
|--------------------------------------------------------------------|----------|-----------------------------------------------------|
| REGISTER DIRECT<br>Data register direct<br>Address register direct | Dn<br>An | <ea> = Dn; n = 1-7<br/><ea> = An; n = 1-7</ea></ea> |
| ADDRESS REGISTER<br>INDIRECT (ARI)<br>ARI with                     | (An)     | <ea> = (An)</ea>                                    |
| postincrement                                                      | (An)+    | $\langle ea \rangle = (An); An + N \rightarrow An$  |
| predecrement                                                       | -(An)    | $An-N \rightarrow An$ ; $\langle ea \rangle = (An)$ |
| displacement                                                       | d(An)    | $\langle ea \rangle = (An + d16)$                   |
| index and displacement                                             | d(An,Rn) | $\langle ea \rangle = (An + Rn + d8)$               |
|                                                                    |          |                                                     |

#### FIGURE 2.8 Register-related addressing modes for the 68000.

In our discussion we will use the three instructions introduced earlier:

CLR <ea> ADD <ea>,Dn

We will also use the initial values of the registers and operands as given in Figure 2.9 for example problems.

It is important to note that although register A7 can be used as an address register in any of the addressing modes, extreme care should be exercised. Since A7 is the sys-

FIGURE 2.9 Initial values for the registers and the data operands in memory.

MOVE <ea>,<ea>

| Memory     | Word |  |
|------------|------|--|
| Address    | Data |  |
| \$0034FE74 | IAB2 |  |
| \$0034FE76 | 3CD4 |  |
| \$0034FE78 | 5EF6 |  |
| \$0034FE7A | 9873 |  |
| \$0034FE7C | 2408 |  |
| :          | :    |  |
| \$00487D6E | CD02 |  |
|            |      |  |

tem stack pointer, it should remain word aligned. In the postincrement and predecrement addressing modes, A7 increments or decrements by two, even if the size of the operand is byte.

### **Register Direct Addressing Modes**

The 68000 has two direct addressing modes: the data register direct and the address register direct.

Data Register Direct Addressing Mode (Dn; n = 1-7) In this mode the specified data register contains the addressed operand. Examples are as follows:

| CLR.L D0 | Clear the long word operand in the D0 register.<br>(Single-operand type; D0 is the destination.)<br>D0 (before) \$ 1 2 3 4 0 6 7 8<br>D0 (after) \$ 0 0 0 0 0 0 0                                                                          |
|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CLR.W DI | Clear the word operand in the D1 register. The lower word in D1<br>gets cleared. The upper word in D1 is not affected.<br>(Single-operand type; D1 is the destination.)<br>D1 (before) \$ A B C D E F 0 0<br>D1 (after) \$ A B C D 0 0 0 0 |

Address Register Direct Addressing Mode (An; n = 1-7) In this mode the specified address register contains the addressed operand. For example,

| MOVEA.L A0,A1 | Move the long-word operand from A0 into A1.<br>A0 is the source operand and is not affected.<br>A1 is the destination operand and is changed. |                                                                                                            |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|
|               | A0 (before)<br>A1 (before)<br>A0 (after)<br>A1 (after)                                                                                        | \$ 0 0 4 8 7 6 F 2<br>\$ 0 0 3 4 F E 7 8<br>\$ 0 0 4 8 7 6 F 2 (no change)<br>\$ 0 0 4 8 7 6 F 2 (changed) |

The register direct addressing modes are very fast and efficient in conducting operations on the data operands already present in the CPU internal registers.

### **Register Indirect Addressing Modes**

The 68000 has five indirect addressing modes: the address register indirect (ARI), the ARI with postincrement, the ARI with predecrement, the ARI with displacement, and the ARI with index and displacement. All these addressing modes provide memory reference where the data operand is located.

Address Register Indirect ARI ((An); n = 1-7) In this mode, the specified address register contains the address of the data operand. An example follows.

MOVE.B (A1),D0

Move the byte operand in memory, the address of which is contained in A1, into D0. Source  $\langle ea \rangle = (A1) =$ \$0034FE78. Byte operand at 0034FE78 = 5E. Destination  $\langle ea \rangle = D0$  register D0 (before) \$12340678 D0 (after) \$1234065E Only the lower byte of D0 is changed to 5E. The other part of D0 is not affected. A1 also is not affected,

**ARI** with Postincrement ((An)+; n = 1-7) In this mode, too, the specified address register contains the address of the data operand. After the operand address is used, the address register is incremented by one, two, or four, depending upon whether the size of the operand is byte, word, or long word. This mode is very useful in setting up and scanning the memory tables. An example follows.

| MOVE.L (A1)+,D1 | Move the long-wo              |
|-----------------|-------------------------------|
|                 | which is contained            |
|                 | crement A1 by four            |
|                 | Source <ea> =</ea>            |
|                 | Long word at \$0              |
|                 | Destination <ea< td=""></ea<> |
|                 | D1 (before)                   |
|                 | A1 (before)                   |
|                 | D1 (after)                    |
|                 | A1 (after)                    |
|                 |                               |

ARI with Predecrement (-(An); n = 1-7) In this mode, the specified address register contains the address of the data operand. It is predecremented by one, two, or four to generate the effective address, depending upon whether the size of the operand is byte, word, or long word. This mode is very useful in setting up and scanning memory tables and in multiprecision arithmetic operations. An example follows.

| word), to obtain th<br>word from that add<br>Source <ea> =<br/>Word operand a<br/>Destination <ea<br>D0 (before) \$<br/>A1 (before) \$<br/>D0 (after) \$<br/>A1 (after) \$</ea<br></ea> | MOVE.W -(A1),D0 | Predecrement A1               |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-------------------------------|
| Source <ea> =<br/>Word operand a<br/>Destination <ea<br>D0 (before) \$<br/>A1 (before) \$<br/>D0 (after) \$</ea<br></ea>                                                                |                 |                               |
| Word operand a<br>Destination <ea<br>D0 (before) \$<br/>A1 (before) \$<br/>D0 (after) \$</ea<br>                                                                                        |                 | word from that ad-            |
| Destination <ea<br>D0 (before) \$<br/>A1 (before) \$<br/>D0 (after) \$</ea<br>                                                                                                          |                 | Source <ea> =</ea>            |
| D0 (before) \$<br>A1 (before) \$<br>D0 (after) \$                                                                                                                                       |                 | Word operand a                |
| A1 (before) \$<br>D0 (after) \$                                                                                                                                                         |                 | Destination <ea< td=""></ea<> |
| D0 (after) \$                                                                                                                                                                           |                 | D0 (before) \$                |
|                                                                                                                                                                                         |                 | A1 (before) \$                |
| Al (after) \$                                                                                                                                                                           |                 | D0 (after) \$                 |
|                                                                                                                                                                                         |                 | Al (after) \$                 |
|                                                                                                                                                                                         |                 |                               |

**ARI** with Displacement (d(An); n = 1-7) In this mode, the specified address register contains the base address. The instruction specifies a sign-extended 16-bit displace-

ord operand in memory, the address of in A1, into the D1 register and postinuг. (A1) = \$0034FE78.0034FE78 = \$5EF69873.i > = D1 register. \$ABCDEF00 \$0034FE78 \$5EF69873 \$0034FE7C

by two (since the size of the operand is he source effective address and move the ldress into D0. = (A1 - 2) =\$0034FE76. at \$0034FE76 = \$3CD4. a > = D0 register. 12340678 0034FE78 12343CD4 0034FE76

ment as the extension word. The sign extension provides an effective displacement range of +32768 (+32K) for positive words and -32768 (-32K) for negative words. (Effective address computations use the sign extension for displacement and index values. Refer to Appendix A for sign-extension concepts).

The effective address is the sum of the base address and the displacement value. The contents of the address register do not change. This mode is very useful in addressing different sections of memory, with different displacement values. An example follows.

#### MOVE.B 0003(A1),D1

Move the byte operand from the computed source <ea> into the D1 register. Effective address computation by the processor is as shown (displacement is 16-bit d16):

> \$0034FE78 Contents of A1 \$0000003 + displacement d16 Source  $\langle ea \rangle = \overline{\$0034FE7B}$

Byte operand at 0034FE7B = 73. Destination <ea> = D1 register. \$ABCDEF00 D1 (before) \$0034FE78 A1 (before) \$ABCDEF73 D1 (after) \$0034FE78 A1 (after) Only the lower byte of D1 is changed to \$73. The other part of D1 is not affected. A1 also is not affected.

ARI with Index and Displacement (d(An,Rn); n = 1-7) In this mode, the specified address register (An) contains the base address. The other address, or data, register (Rn) contains an index word (or long word), as specified. The instruction also specifies an 8bit sign-extended displacement as a part of the extension word. The index operand can be a computed variable, which provides a dynamic addressing scheme.

The effective address is the sum of the base address, the index value, and the displacement. The contents of the address and index registers do not change. This mode is very useful in addressing different sections and blocks of memory with different index and displacement values.<sup>9</sup> An example follows.

| MOVE.W 04(A0,D0.W),D1 | Move the word operand from the source $\langle ea \rangle$ into D1. The $\langle ea \rangle$ computation by the processor is as shown (displacement is 8-bit d8).           |
|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                       | Contents of A0<br>+ index word from D0<br>+ displacement d8<br>Source $\langle ea \rangle = \frac{\$004876F2}{\$0000004}$                                                   |
|                       | Word operand at \$00487D6E = \$CD02.         D0 (before)       \$ 1 2 3 4 0 6 7 8         D1 (before)       \$ A B C D E F 0 0         A0 (before)       \$ 0 0 4 8 7 6 F 2 |

| D0 (after)     | \$ | 1   | 2   | 3   | 4  | 0  | 6  | 7  | 8   |
|----------------|----|-----|-----|-----|----|----|----|----|-----|
| D1 (after)     | \$ | А   | B   | С   | D  | C  | D  | 0  | 2   |
| A0 (after)     | \$ | 0   | 0   | 4   | 8  | 7  | 6  | F  | 2   |
| Only the lower | w  | ord | l o | f E | )] | is | ch | an | ged |

Depending upon the application, any of the preceding addressing modes can be used to specify' either the source or the destination operands. In some instances, not all the addressing modes are applicable. The instruction set specifies which modes are applicable^ and which are not.

Any type of data structure can be set up and handled using the preceding addressing modes. For example, the predecrement and postincrement addressing modes can be used in conjunction with each other to set up a stack-type or queue-type activity. Within the same instruction, the source and destination operands can be specified by different addressing modes.

The following example problem provides a review of the register-related addressing modes.

#### Example 2.3 Register addressing modes for the 68000.

According to the instruction structure and the addressing modes discussed so far, specify what occurs in each of the following operations. Also, indicate the contents of the corresponding registers and the memory locations after each operation. The initial values in each case are as shown in Figure 2.9.

1. MOVE.B D1,D0

**2.** CLR.L -(A1)**3.** MOVE.W (A1)+,0A(A0,D0.W)

#### Solution

1. MOVE.B D1,D0: D1 is the source operand. D0 is the destination operand. The source and the destination operands are specified by the data register direct addressing mode. The lower byte operand from D1 is moved to D0. Only the lower byte of D0 is changed.

> D0 (before) \$12340678 D0 (after) \$12340600

2. CLR.L -(A1): The operand is specified by the ARI with predecrement addressing mode. A1 is predecremented by four (since the operand is long word) to obtain the effective address, and the long word at the location is cleared.

> Destination  $\langle ea \rangle = (A1-4) =$ \$0034FE74. A1 (before) \$0034FE78 A1 (after) \$0034FE74

#### 2.4 IMMEDIATE, QUICK, ABSOLUTE, RELATIVE,

| Memory address<br>\$0034FE74<br>\$0034FE76<br>\$0034FE78 | Memory of            | contents             |
|----------------------------------------------------------|----------------------|----------------------|
|                                                          | before               | after                |
|                                                          | 1AB2<br>3CD4<br>5EF6 | 0000<br>0000<br>5EF6 |
| :                                                        | :                    | :                    |
| :                                                        | :                    | :                    |

3. MOVE.W (A1)+,0A(A0,D0.W): The source operand is specified by the ARI with postincrement mode of addressing. The destination operand is specified by the ARI with index and displacement mode of addressing. The word from the source <ea> is moved to the destination <ea>.

```
Source \langle ea \rangle = (A1) = $0034FE78.
                  Destination <ea> computation:
                                         $004876F2
                       Contents of A0
                                         $00000678
               + index word from D0
                                         $000000A
                    + displacement d8
                    Destination \langle ea \rangle = \overline{\$00487D74}
Word at location $0034FE78 ($5EF6) is moved to location $00487D74.
                                   $0034FE78
                    A1 (before)
                                    $0034FE7C
                    A1 (after)
                    (postincremented by four)
           Memory word at $00487D74 (before)
                                                    not known
                                                    $5EF6
                                        (after)
```

The addressing modes discussed so far address the data or the address operands. We will now introduce the other modes that deal with the program control, in addition to addressing the operands.

### AND IMPLICIT ADDRESSING MODES

Figure 2.10 illustrates the aforementioned addressing modes. In the immediate and quick addressing mode, the data is explicitly specified as part of the instruction. In the absolute addressing mode, the address of the data or of the next instruction is explicitly specified as part of the instruction. In the relative addressing mode, a displacement where the data or the next instruction is located is explicitly specified as part of the instruction. In the implicit addressing mode, instructions make implicit reference to the processor registers. We will now discuss the details of these addressing modes using the three instructions (CLR <ea>; ADD <ea>,Dn; and MOVE <ea>,<ea>) introduced earlier. The initial values of the registers and the operands given in Figure 2.11 will be used for examples.

| Addressing Mode                         | Syntax                  | Effective Address <ea></ea>                                    |
|-----------------------------------------|-------------------------|----------------------------------------------------------------|
| Immediate addressing                    | #XXX or IMM             | <ea> = next one or two<br/>words of the in-<br/>struction</ea> |
| Quick addressing                        | Instruction ends with Q | Data contained as part of the op.word                          |
| Absolute short addressing               | XXXX or ABS.W           | <ea> = next word of the<br/>instruction</ea>                   |
| Absolute long addressing                | XXXXXXXX or ABS.L       | <ea> = next two words of<br/>the instruction</ea>              |
| PC relative with displace-<br>ment      | d(PC)                   | $\langle ea \rangle = (PC + d16)$                              |
| PC relative with index and displacement | d(PC,Rn)                | $\langle ea \rangle = (PC + Rn + d8)$                          |
| Implicit                                | None                    | $\langle ea \rangle = PC, SR, SP. \dots$                       |

## FIGURE 2.10 Immediate, quick, absolute, relative, and implicit addressing modes for the 68000.

### Immediate Addressing Mode (Imm)

Maria I. I. I.

Data are explicitly specified and contained in the extension words of the instruction. Data size can be a byte, a word, or a long word. For long-word data operands, two word extensions are required. This addressing mode is very useful in initializing the registers and the memory. Only the source operand can be specified by this addressing mode. We will use a # sign to signify the immediate operand. Examples are as follows:

| D0 = \$ 1 2 3 4 0 6 7 8 | Memory     | Word    |
|-------------------------|------------|---------|
| D1 = \$ABCDEF00         | Address    | Data    |
| A0 = \$ 0 0 4 8 7 6 F 2 | \$0034FE74 | 1 A B 2 |
| A1 = \$ 0 0 3 4 F E 7 8 | \$0034FE76 | 3CD4    |
|                         | \$0034FE78 | 5EF6    |
|                         | \$0034FE7A | 9873    |
|                         | \$0034FE7C | 2408    |
|                         | :          | :       |
|                         | :          | :       |
|                         | \$00487D6E | CD02    |

FIGURE 2.11 Initial values for the registers and the data operands in memory.

| MOVE.B #\$2A,D0     | Move the immediate data byte \$2A into the D0 desti-<br>nation register.<br>D0 (before) \$12340678<br>D0 (after) \$1234062A                                                                |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MOVE.W #\$BBBB,(A1) | Move the immediate data word \$BBBB into memory<br>addressed by (A1).<br>Destination $\langle ea \rangle = (A1) = $0034FE78$ .<br>Contents of \$0034FE78 (before) \$5EF6<br>(after) \$BBBB |

#### Quick Addressing Mode (....Q)

This is a variation of the immediate addressing mode. Up to 8 bits of data can be specified as part of the operation word itself. Thus, this is a single-word instruction and operates faster than the immediate addressing mode. However, the data range is limited to 8 bits in move operations and to 8 units in arithmetic operations. In this addressing mode, all 32 bits of the destination are affected by the sign extension of the data operand. In the sign extension, the most significant bit (MSB) of the data operand is replicated to all the higher bits (see Appendix A). The instructions allowed in this mode are explicitly specified in the instruction set and end with Q (ADDQ, MOVEQ, SUBQ, and so forth). An example follows.

| MOVEQ #\$43,D0 | Move the quick data \$43 into the D0 destination register.<br>Data operand = $$43 = 0 \ 1 \ 0 \ 0 \ 0 \ 1 \ 1$ |
|----------------|----------------------------------------------------------------------------------------------------------------|
|                | MSB = 0                                                                                                        |
|                | This MSB is replicated to all the higher bits in D0 register.                                                  |
|                | D0 (before) \$12340678                                                                                         |
|                | D0 (after) \$ 0 0 0 0 0 0 4 3                                                                                  |
|                |                                                                                                                |

#### Absolute Short and Long Addressing Modes (Abs.W, Abs.L)

In the absolute short addressing mode, a 16-bit address of the data or of the next instruction is explicitly specified as an extension word within the instruction. In the absolute long addressing mode, instead of the 16-bit address, a 32-bit address is specified as two extension words within the instruction. The short addressing mode has a range of 64 kilobytes and the long addressing mode has a range of 16 megabytes. These addressing modes are used to access the memory directly. They are also used in program control applications to specify the location of the next instruction. Examples are as follows:

CLR.L \$0034FE74

Clear the long-word operand starting at memory location 034FE74. This is the absolute long addressing mode, since a 32-bit address of the operand is specified. Destination  $\langle ea \rangle = 0034FE74$ . Long-word operand at 0034FE74(before) 1 A B 2 3 C D 4(after) 0 0 0 0 0 0 0 0 MOVE.B D0,\$4000

Move the byte operand from D0 into the memory location at \$4000. Destination of the 16-bit address is specified by the absolute short addressing mode. The upper four digits of the address are considered to be \$0000. Source operand = byte from D0 = \$78 Destination  $\langle ea \rangle =$ \$00004000 Byte operand at \$00004000 (before) not known (after) \$78

### PC Relative with Displacement Addressing Mode d(PC)

In this addressing mode, a signed displacement is specified as a part of the instruction. This displacement is added to the contents of the PC (program counter) to obtain the effective address of the operand.

The displacement can be 8 or 16 bits, depending upon the instruction. For an 8-bit displacement, the displacement range is 256 bytes; for a 16-bit displacement, it is 64 kilobytes.

Program control instructions, such as BRANCH instructions, use this type of addressing mode. In the example that follows, we will introduce a new instruction, **BRA** (**branch always**). This specifies where the next instruction to be executed is to be found.

#### PC Instruction

| \$00002000 | BRA 082A(PC) | Branch to the specified<br>calculation is as shown:<br>Contents of PC after the | effective address. The <ea></ea> |
|------------|--------------|---------------------------------------------------------------------------------|----------------------------------|
|            |              | instruction*                                                                    | \$00002002                       |
|            |              | + sign-extended 16-bit                                                          |                                  |
|            |              | displacement                                                                    | <u>\$0000082A</u>                |
|            |              |                                                                                 | < ea > = <u>\$0000282C</u>       |
|            |              | The program branches t                                                          | to \$0000282C and fetches the    |
|            |              | next instruction from that                                                      | t location.                      |

\*Recall that the PC advances to next word location after fetching the present op.word. Thus, the PC will be at \$00002002 after fetching the BRA instruction.

# PC Relative with Index and Displacement Addressing Mode d(PC,Rn)

In this addressing mode, in addition to the displacement, the instruction specifies an index register. The effective address is the sum of the contents of the PC, the index register, and the displacement. The displacement is 8 bits. An example follows.

#### PC Instruction

| S00487708 | MOVE.W EC(PC,D0.W),D1 | Move the word operand from the source              |
|-----------|-----------------------|----------------------------------------------------|
|           |                       | <ea> into D1. The <ea> calculation is as</ea></ea> |
|           |                       | shown.                                             |

\$0048770A Contents of PC after the MOVE instruction\* \$0000678 + sign extended index word from D0 Indexed address = \$00487D82+ sign-extended displacement<sup>†</sup> = \$FFFFFFEC < ea > = \$00487D6EWord operand from 00487D6E = CD02D1 (before) \$ABCDEF00 \$ABCDCD02 D1(after)

\*PC advances to the next word location (\$0048770A) after the MOVE instruction. tSign extended to 32 bits. \$EC is a negative number that corresponds to -\$14 in twoscomplement notation. (Refer to Appendix A for twos-complement concepts.)

The PC relative addressing modes are used extensively in program control applications. In addition, these addressing modes are used in applications requiring program code relocation. In such applications, the program code can be made to reside in any part of memory, and the PC can be adjusted accordingly. Any memory reference will be with respect to the adjusted PC as the base address and will be valid.

#### Implicit Addressing Mode

The 68000 has certain instructions that make implicit reference to the processor registers (the PC, SR, SP, and so forth). This mode works in conjunction with the other addressing modes. Sometimes it is not considered to be a separate addressing mode. An example follows.

MOVE.W #\$0400,SR Move the immediate word operand \$0400 into the SR (status register).\* The source operand is specified by the immediate addressing mode. Destination <ea>, which is the SR, is specified by the implicit reference. SR (before) not known \$0400 SR (after)

\*This instruction dealing with the SR is privileged and can only be used in the supervisor mode.

The following example problem provides a review of the addressing modes we have discussed.

#### Example 2.4 Other addressing modes for the 68000.

Use the initial values given in Figure 2.11. Specify what occurs in each of the following operations. Indicate the contents of the corresponding registers and memory locations after each operation. Consider the same initial values for each of the operations.

#### 1. MOVE.L #\$765432AC.\$0034FE74

- 2. ADDQ.B #\$04,D1
- 3. MOVE.W \$007A(PC),SR (Contents of PC \$0034FE00)

#### Solution

- Add the immediate (quick) operand to the destination <ea>.
  - Dl (after)
- moved into SR.

In software applications using the 68000 microprocessor, all of the 14 addressing modes can be used in conjunction with each other. Certain addressing modes, however, may preclude some instructions. This information is available from the instruction set. Care should be taken to ensure that an invalid addressing mode is not used to specify operands. Similarly, word and long-word operands should not be accessed at the odd address boundaries. To do so would result in error conditions.

### 2.5 SUMMARY

In this chapter we discussed the memory organization schemes, data structures, and addressing modes for the 68000 processor.

1. MOVE.L #\$76543fAC,\$0034FE74: The source operand is specified by the imme diate addressing mode and the destination effective address is specified by the abso lute long addressing mode. The source operand is moved to the destination <ea>./ Source long word = \$765432AC

Destination <ea> = \$0034FE74 Long-word operand at \$0034FE74 (before) = \$1AB23CD4 (after) = \$765432AC

2. ADDQ.B #\$04,D1: The source operand is specified by the quick addressing mode and the destination operand is specified by the data register direct addressing mode.

> Source operand (byte) = \$04. Destination  $\langle ea \rangle = Dl$  register. Source data \$04 is added to the Dl register. Dl (before) \$ A B C D E F 0 0 \$ A B C D E F 0 4

3. Move.W \$007A(PC),SR: With contents of PC = \$0034FE00, the effective address of the source operand is \$0034FE7A. The contents at that address (= \$9873) are

SR (after) = \$9873

The memory is organized as 16-bit words consisting of blocks of even and odd bytes. The bytes can be accessed individually, the words can be accessed as two bytes, and the long words can be accessed as two words. Words and long words should be accessed only at the even address boundaries. To do otherwise would result in an error condition. The 68000 processor follows memory-mapped I/O (input/output) in which the processor communicates with an I/O device as if it were one of the memory locations. The total address space for the 68000 processor can be considered as 16 megabytes or 8 megawords.

The important data structures of the 68000 are the stack and the queue. The stack is a LIFO data structure in the memory. Some of the internal registers are saved on the stack in the case of a change in program flow due to subroutines or exceptions. USP controls the stack if the processor is in the user mode; SSP controls the stack if the processor is in the supervisor mode. The stack fills from high memory to low memory on a push-type stack operation. The stack is word sized and word aligned and should only be accessed at even address boundaries.

The queue is a FIFO data structure in the memory and can be set up to fill in from high memory to low memory or vice versa. The queue is very useful in setting up tables and strings.

For the 68000, instructions are from one to five words. The first word, which is the operation word (op. word), specifies the type of operation. The rest of the words contain the appropriate extensions and operands. The structure of the instruction consists of the instruction field and the source and destination fields. Instructions may be of the single-or double-operand type. In the single-operand type, the specified operand is the destination operand on which the given operation is performed. In the double-operand type, the first operand is the source operand and the second is the destination operand. After performing the operation, the final result is put in the destination.

The 68000 has 14 different addressing modes with which to access the source and destination operands. In the register direct addressing modes, either a data register or an address register contains the specified operand. In the register indirect addressing (ARI) modes, one of the address registers contains the base address. There may be index and displacement values specified as a part of the instruction. These may be added to the base address to obtain the effective address of the operand.

In the immediate and quick addressing modes, the instruction contains the data operand. In the absolute addressing modes, the instruction contains the address of the operands. In the PC relative addressing modes, the PC contains the base address. There may be index and displacement values specified as part of the instruction. These may be added to the base address to obtain the effective address of the operand. The implicit addressing mode makes an implicit reference to some of the internal registers of the processor.

These addressing modes all can be used in conjunction with one another to specify the source and destination operands. The source operand can be specified by one addressing mode and the destination operand by another. This flexibility allows the 68000 processor to access operands conveniently and efficiently.

#### PROBLEMS

2.1 Draw the conceptual memory organization schemes for the following processors:(a) the 68008 microprocessor;

(b) the 68010 microprocessor.

2.2 The 68000 is accessing a word operand from the memory. The memory word is \$234A. Specify the fallowing:(a) contents of data bus D0-D7 and D8-D15:

(b) logic levels of the LDS. UDS. and R/W strobes.

- 2.3 What are the contents of the strobes LDS, UDS, and R/W and the data bus D0-D15 when the 68000 is writing the long-word operand IAABBCCDD into memory location \$004000.
- 2.4 Suppose the LDS and the UDS connections have been interchanged in Figure 2.1. What would happen in the following situations:

(a) the 68000 is trying to read byte operand \$45 from memory location \$00001000;(b) the 68000 is trying to write byte operand \$54 into memory location \$0000100B.

- 2.5 Long-word operands \$124680AB and \$78908762 are stored in sequential memory locations beginning at \$00002000. BCD data string 1200340045974 is stored beginning at the next sequential location. Show how data are physically stored in the following systems:
  - (a) the 68000-based system;
  - (b) the 68008-based system;
  - (c) the 68010-based system.
- 2.6 Show how the following data elements are stored in memory for a 68000-based system:
  - (a) hex string \$1234432156788765ABCDDCBA, starting from memory location \$00004000;
  - (b) the hex string given in (a), but in the form of a word-aligned queue starting from \$00004040 and filling in towards high memory address.
- 2.7 The system stack pointer has an initial value \$000034AO. Show how the following data elements are stored on the stack:

#### first element \$0010 second element \$0020

ninth element \$0090 What are the contents of the stack pointer after the ninth element has been stored?

- 2.8 Fiach subroutine call stores the program counter on the system stack. Each exception-, such as interrupt, stores the program counter and the status register on the stack.
  - (a) In a control system application, 128 bytes of stack space is allocated for the user mode of operation. How many subroutines can be nested if the stack is not used for any other storage?
  - (b) Repeat (a) if the DO and DI registers are also to be stored on the stack each time a subroutine call occurs. *[Note:* separate instructions are to be written to store any registers other than the PC on the stack during subroutine calls.)
- 2.9 In a robotics system application using the 68000, 512 bytes of supervisor stack space is allocated. Each robotics motor requires one interrupt service routine, which nests eight subroutines.

- (a) How much stack space is used up for each robotics motor application?
- (b) How many of these robotics operations can be nested?
- 2.10 Following the instruction format of Figure 2.5, conceptualize how the following instructions are stored in the memory for a 68000-based system:
  - (a) CLR.L <ea>; <ea> corresponds to a 32-bit address; (b) ADD.W <ea>,Dl; <ea> corresponds to a 32-bit address;
  - (c) MOVE.L <ea>,<ea>; each <ea> corresponds to a 32-bit address.
- **2.11** Given the instruction structure of Figure 2.6, write instructions to accomplish the

#### following tasks:

- (a) clear a byte in the D7 register;
- (b) move a long word from A6 into the D5 register;
- (c) add the long-word contents from D6 to the long-word contents of D7, with the result inD6
- 2.12 Write a sequence of instructions to accomplish the following tasks:
  - (a) add the word contents from D5 to the long-word contents in D6 and put the result in the D7 register;
  - (b) clear the long word in the D3 register and transfer the result to the A3 register.
- **2.13** Using the initial values as given in Figure 2.9, specify the results of the following

#### operations:

- (a) ADD.LD1.D0 (b) ADD.W A0,D1
- (c) MOVE.B -(Al).-(Al)

Clearly specify the source and destination addressing modes. Show the contents of the

affected registers, the SR, and the memory.

2.14 Repeat Problem 2.13 with the condition that the operations are done in sequence, affecting

#### the values accordingly.

- 2.15 Transfer the long-word contents from \$0034FE76 into the DI register using the following addressing modes:
  - (a) ARI with displacement;
  - (b) ARI with index and displacement;
  - (c) absolute long.

Write the appropriate instruction in each case, using the same initial values given in Figure

2.9. 2.16 The PC is at location \$0034FE00 after the appropriate op.word has been read, which transfers the long-word contents from S0034FE76 into the Dl register. Write the instructions needed to reach this condition using the following addressing modes:

- (a) PC relative with displacement;
- (b) PC relative with index and displacement;
- (c) any other mode of your choice.

Use the initial values given in Figure 2.9. 2.17 Using the same initial values, specify the contents of the registers and the memory after accomplishing each of the following operations:

- (a) MOVE.L -(A1),(A0)+
- (b) ADD.W -(Al).-(Al)
- (c) CLR.B \$0034FE75

- affecting the values accordingly.
- which generate error conditions? Why?

(a) ADD.W \$0003(A1),DO (b) MOVE.B \$00(A1.DO,L),D1 (c) JSR \$0305 /^

(a) ADD.L#\$10101010,DO (b) ADDQ.L #\$03,(A1)+ (c) MOVE.L #\$00100100,(A1)+

Show the contents of the affected registers, the SR, and the memory. 2.21 Repeat Problem 2.20 with the condition that the operations are done in sequence, affecting

- the values accordingly.
- **2.22** Specify whether the following are true or false:

### **ENDNOTES**

- Edition. Englewood Cliffs, NJ: Prentice-Hall, 1987.

- 808518080A. Columbus, OH: Merrill, 1984.
- Cliffs, NJ: Prentice-Hall, 1984.
- 8. Cohen, K. "Multiprocessor Architecture." Electronics (May 1983).
- Technical Operations, 1986.

**2.18** Repeat Problem 2.17, with the condition that the operations are done in sequence,

**2.19** With the initial values of Figure 2.9, which of the following operations are valid and

2.20 Specify the results of the following operations, using the same initial values:

(a) the immediate addressing mode cannnot be used to specify the destination operand. (b) the quick addressing mode can be used to specify data elements of any size. (c) the PC relative addressing mode cannot be used to specify odd memory locations. (d) the implicit addressing mode cannot refer to external memory.

1. Motorola, Inc. MC68000 Data Book. Phoenix, AZ: Motorola Technical Operations, 1983. 2. Motorola, Inc. M68000 16132 Bit Microprocessor Programmer's Reference Manual, Fifth

3. Motorola, Inc. MC68008 Data Book. Phoenix, AZ: Motorola Technical Operations, 1983. 4. Stranes, T. "Design Philosophy Behind the M68000." Byte (Apr., May, Jun. 1983). 5. Gaonkar, R. Microprocessor Architecture, Programming, and Applications with the

6. Stranes, T. "Design Philosophy Behind the M68000." Byte (Apr., May, Jun. 1983). 7. Subbarao, W. Microprocessors: Hardware, Software, and Design Applications. Englewood

9. Motorola, Inc. M68000 vs. IAPX86 Benchmark Performance. Phoenix, AZ: Motorola

## CHAPTER

# 3

# The 68000 Instruction Set and Programming Considerations

#### Objectives

In this chapter we will study:

The general instruction set of the 68000 The data movement group of instructions and applications Binary and BCD arithmetic groups of instructions and applications Logical and bit-manipulation groups of instructions and applications Program and system control groups of instructions and applications Instruction timing considerations and applications

#### 3.0 INTRODUCTION

The 68000 has a powerful instruction set, including 56 generic instruction types. Some of these instruction types have several variations. In addition, the 14 addressing modes discussed in the previous chapter can be used in conjunction with the instructions. This provides the 68000 with tremendous software capability.'

The instructions are designed to follow a consistent structure. The same mnemonic statement representing an instruction can be used with appropriate attributes to refer to different operand sizes and addressing modes.

A clear understanding of how these instructions work, how they affect the status bits in the status register, and which of the addressing modes can be used is essential to the study of the software features and the programming techniques of the 68000 processor.

We will first introduce the general instruction set, categorize it into groups, and then discuss the essential features of each of the groups with appropriate illustrations. This approach will help us gain better insight into the instruction set. The material covered will provide the necessary background for writing programs using the 68000 processor.

#### 3.1 THE GENERAL INSTRUCTION SET

Figure 3.1 indicates the general instruction set for the 68000 microprocessor in tabular form. In the first column the instruction mnemonic used in writing the assembly programs is given. The second column contains the physical description of the instruction. The third column lists the actual operation, and the last columns describe how the flags are affected in the case of each instruction. Figure 3.2 shows how the condition codes ate computed. In Appendix B, details of the instruction set arc presented.<sup>2</sup> The reader should refer to this appendix in studying the concepts covered in this chapter.

#### Interpretation of the Instructions

Consider the second instruction in the table in Figure 3.1. It is the ADD instruction with which we are already familiar. The description indicates that it is a binary addition. The data operands will be interpreted as binary numbers. The operation indicates that the destination operand is added to the source operand, and the final result is put in the destination. We see that all of the condition codes, known as **flags** or **status bits**, are affected by this operation. Any of them can be used for decision making in a programming sequence.

The syntax, attributes, and addressing modes for the ADD instruction are as follows (see also Appendix B): $^{3}$ 

Assembler Syntax:ADD <ea>,Dn or ADD Dn,<ea>Attributes (size):Byte, word, or long word.

|             | · · · · · · · · · · · · · · · · · · ·              | Operation                                                                                     | Condition<br>Codes |               |       |            |          |
|-------------|----------------------------------------------------|-----------------------------------------------------------------------------------------------|--------------------|---------------|-------|------------|----------|
| Mnemonic    | Description                                        |                                                                                               |                    |               |       | _          | C        |
|             | Add Decimal with Extend                            | (Destination) 10+ (Source) 10+ X - Destination                                                | - 1 -              | ų.            | -     | U          | -        |
| BCD         |                                                    | (Destination) + (Source) Destination                                                          | <u>'</u>           | 4             | _     | -          | <u> </u> |
| DD          | Add Binary                                         | (Destination) + (Source) - Destination                                                        | -                  | 井             | 듺     | -          | -        |
| DDA         | Add Address                                        | (Destination) + Immediate Data → Destination                                                  | -                  | ~ I           | ÷     | *          | -        |
| DDI         | Add Immediate                                      | (Destination) + Immediate Data - Destination                                                  | •                  | -             | -     |            | -        |
| 000         | Add Quick                                          | (Destination) + (Source) + X - Destination                                                    | -                  | -             | _     | 1          | Ļ        |
| DDX         | Add Extended                                       | (Destination) ∧ [Source) → Destination                                                        | -                  | -             | *     | 0          | 0        |
| ND          | AND Logical                                        | (Destination) ∧ Immediate Data → Destination                                                  | -1                 | *             | -     | <u> </u> ₽ | 0        |
| NDI         | AND Immediate<br>AND Immediate to Condition Codes  | ISource) & CCB-+CCB                                                                           | •                  | •             | -     | Ľ          | Ļ        |
| NDL to CCR  | AND Immediate to Collation Codes                   | (Source) A SB - SB                                                                            | *                  | •             | -     | Ľ          | Ľ        |
| ANDI to SR  | AND Immediate to Status Register                   | (Destination) Shifted by <count> -&gt; Destination</count>                                    | *1                 | •             | *     |            | Ľ        |
| ASL, ASR    | Arithmetic Shift                                   | If CC then PC+d-PC                                                                            | -                  | -             | -     |            | Ŀ        |
| 300         | Branch Conditionally                               | ( dist number >1 OF Destination -+ Z                                                          | Т                  | -1            |       |            | L        |
|             |                                                    | (< bit number>) OF Destination —*                                                             | -                  | -             | 1T    | 1~         | 1-       |
| BCHG        | Test a Bit and Change                              | < bit number > OF Destination                                                                 | -+                 |               | ⊢     | ╋          | ┢        |
|             |                                                    | $I_{\alpha}$ (< bit number>) OF Destination $\rightarrow Z$                                   | -                  | -             | * (   | 1-         | -        |
| BCLR        | Test a Bit and Clear                               | 0 → < bit number > → OF Destination                                                           | +                  |               | ⊢     | ╉╸         | +        |
|             | Branch Always                                      | PC+d→PC                                                                                       | -                  | Ē             | ╞     | +          | Ŧ        |
| BRA         |                                                    | -( <bit number="">) OF Destination →Z</bit>                                                   | -                  | -             | ۱.    | ·۱-        | · -      |
| BSET        | Test a Bit and Set                                 | 1 →<br>dit number> OF Destination                                                             | $\vdash$           |               | +     | +-         | t        |
| 000         | Branch to Subroutine                               | $PC \rightarrow -(SP); PC + d \rightarrow PC$                                                 | F                  |               | ╞     | ֠          | t        |
| BSR         | Test a Bit                                         | ~ ( <bit number="">) OF Destination → Z</bit>                                                 | Ę.                 | -             | h     | ili        |          |
| BTST        | Check Register Against Bounds                      | If Dn <0 or Dn> ( <ea>) then TRAP</ea>                                                        |                    | l             |       |            | - i-     |
| СНК         | Clear and Operand                                  | 0 -> Destination                                                                              | -                  | 0             | _     | +          |          |
| CLR         |                                                    | (Destination) - (Source)                                                                      | 1-1                | Ļ             | +     | -+;        | +        |
| CMP         | Compare Address                                    | (Destination) – (Source)                                                                      | -                  | Ļ             |       | -          | +        |
| СМРА        | Compare Immediate                                  | (Destination) – Immediate Data                                                                | ╞                  | Ļ             | $\pm$ | +          | +        |
| CMPI        | Compare Memory                                     | (Destination) - (Source)                                                                      | 1-                 | Ľ             | 1     | -          | ╞        |
| CMPM        | Test Condition, Decrement and Brand                | the lif $\sim$ CC then Dn - 1 $\rightarrow$ Dn, if Dn $\neq$ - 1 then PC + d $\rightarrow$ PC | Ŀ                  | Ŀ             | ÷     | 1          | ÷        |
| DBCC        |                                                    | (Destination)/(Source) - Destination                                                          | +-                 | Į,            | +     |            | •        |
| DIVS        | Signed Divide                                      | (Destination)/(Source) - Destination                                                          | ╘                  | +             | _     | <u> </u>   | - 1      |
| DIVU        | Unsigned Divide                                    | (Destination) ⊕ (Source) → Destination                                                        | 1-                 |               |       | _          | 0        |
| EOR         | Exclusive OR Logical                               | (Destination) @ Immediate Data - Destination                                                  | ╘                  |               | 4     | 1          | 0        |
| EORI        | Exclusive OR Immediate                             |                                                                                               |                    | ۰ŀ            | ٠Į    | •          | •        |
| EORI to CCR | Exclusive OR Immediate<br>to Condition Codes       | (Source) ⊕ CCR → CCR                                                                          | Ŧ,                 | $\frac{1}{2}$ | +     | +          | *        |
| EORI to SR  | Exclusive OR Immediate<br>to Status Register       | (Source) ⊕ SR-+SR                                                                             |                    | 4             | -+    | 4          | 4        |
| <u> </u>    | Exchange Register                                  | Rx ↔ Ry                                                                                       | ╞                  | -+-           | 7     | ÷ŀ         | - 0      |
| EXG         | Sign Extend                                        | (Destination) Sign-Extended Destination                                                       | ╞                  | 4             | 4     | -1         | v        |
| EXT         |                                                    | Destination PC                                                                                | 1                  | 4             | 4     | -          | _        |
| JMP         | Jump<br>Jump to Subroutine                         | $PC \rightarrow -(SP)$ ; Destination $\rightarrow PC$                                         | ÷                  | 4             | -     | ᅴ          | -        |
| JSR         | Load Effective Address                             | $\langle an \rangle \rightarrow An$                                                           | 4                  | -             | -     | -          | _        |
| LEA         |                                                    | $A_{P} \rightarrow \pi$ (SP); SP $\rightarrow$ An; SP + Displacement $\rightarrow$ SP         | ÷                  | -             | 긁     | اپتا       | -        |
|             | Link and Allocate                                  | (Destination) Shifted by <count> - Destination</count>                                        | 1                  |               |       | Ľ          | 0        |
| LSL, LSR    | Logical Shift<br>Move Data from Source to Destinat |                                                                                               | ÷                  | -             | *     | Ļ          | 0        |
| MOVE        | Move Data from Source to Destinet                  | (Source) - CCR                                                                                | _                  | *             | -     | Ē          | ÷        |
| MOVE to CC  | R Move to Condition Code                           | (Source) - SR                                                                                 |                    | *             | *     | Ľ          | Ľ        |
| MOVE to SR  | Move to the Status Register                        |                                                                                               |                    | af            | fec   | ted        |          |
|             |                                                    | A logical AND                                                                                 |                    |               |       | lfec       | ted      |
|             |                                                    | V logical OR<br>⊕ logical exclusive OR                                                        | 0                  | cle           | eare  |            |          |
|             |                                                    |                                                                                               |                    | SØ            |       |            |          |

| Mnemonic                              | Description                                  | Operation                                                                                                                      |                               | Conditio   |          |    |  |  |
|---------------------------------------|----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|-------------------------------|------------|----------|----|--|--|
|                                       |                                              |                                                                                                                                |                               |            |          |    |  |  |
| MOVE from SR                          | Move from the Status Register                | SR -+ Destination                                                                                                              | - +                           | <u> </u>   | +        | +  |  |  |
| MOVE USP                              | Move User Stack Pointer                      | USP→An; An → USP                                                                                                               | -                             | +          | +        |    |  |  |
| MOVEA                                 | Move Address                                 | (Source) → Destination                                                                                                         |                               | t          | +        |    |  |  |
| MOVEM                                 | Move Multiple Registers                      | Registers → Destination<br>(Source) → Registers                                                                                |                               | 1          | +        |    |  |  |
| MOVEP                                 | Move Peripheral Data                         |                                                                                                                                | +-                            | ╇          | +-       |    |  |  |
|                                       | Move Quick                                   | (Source) → Destination                                                                                                         |                               | +          |          |    |  |  |
|                                       | Signed Multiply                              | (Destination)X(Source) → Destination                                                                                           |                               | ╞          | -        | 1. |  |  |
|                                       | Unsigned Multiply                            | {Destination(X(Source) → Destination                                                                                           |                               | 1          |          | Ľ  |  |  |
|                                       | Negate Decimal with Extend                   |                                                                                                                                |                               | <u> </u>   | -        | 1, |  |  |
|                                       | Negate Decimal With Exterio                  | 0- (Destination) <sub>10</sub> - X → Destination                                                                               |                               | 1          |          | 4  |  |  |
|                                       | Negate with Extend                           | 0 - (Destination) - Destination                                                                                                | <u> </u>                      | .          |          | +  |  |  |
|                                       | No Operation                                 | 0 – (Destination) – X → Destination                                                                                            |                               | Ľ          | 1.       | L  |  |  |
|                                       |                                              |                                                                                                                                |                               |            | +-       | Ŀ  |  |  |
|                                       | Logical Complement                           | ~(Destination) - Destination                                                                                                   |                               | *          | 1        | Ļ  |  |  |
|                                       | Inclusive OR Logical                         | (Destination) v (Source) → Destination                                                                                         |                               | 1.         | Ţ,       | 1  |  |  |
|                                       | Inclusive OR Immediate                       | (Destination) v Immediate Data - Destination                                                                                   |                               | *          | 1.       | 1  |  |  |
| ORI to CCR                            | Inclusive OR Immediate<br>to Condition Codes | (Source) y CCR CCR                                                                                                             | •                             | •          | •        | ŀ  |  |  |
| ORI to SR                             | Inclusive OR Immediate<br>to Status Register | Sourcet v SR → SR                                                                                                              | *                             | *          | *        | Γ. |  |  |
| PEA                                   | Push Effective Address                       | <ea>→ - (SP)</ea>                                                                                                              | 1-                            | 1-         | 1-       | 1- |  |  |
| RESET                                 | Reset External Device                        | -                                                                                                                              |                               | 1-         | t        | t  |  |  |
| ROL, ROR                              | Rotate (Without Extend)                      | (Destination) Rotated by < count > → Destination                                                                               | -                             | *          | •        | t  |  |  |
| ROXL, BOXR                            | Rotate with Extend                           | (Destination) Rotated by < count > Destination                                                                                 | -                             | 1.         | *        | ta |  |  |
| RTE                                   | Return from Exception                        | $(SP) + \rightarrow SR; (SP) + \rightarrow PC$                                                                                 | *                             | *          | *        |    |  |  |
| RTR                                   | Return and Restore Condition Codes           | $ (SP) + \rightarrow CC; (SP) + \rightarrow PC$                                                                                |                               | ╞┲         | 1.       | 1, |  |  |
| RTS                                   | Return from Subroutine                       | $(SP) + \rightarrow PC$                                                                                                        |                               | ┞_         | +-       | 1- |  |  |
| SBCD S                                | Subtract Decimal with Extend                 | (Destination) 10 - (Source) 10 - X → Destination                                                                               | *                             | ĺυ         | •        | t  |  |  |
| S <sub>CC</sub>                       | Set According to Condition                   | If CC then 1's - Destination else 0's - Destination                                                                            |                               | -          |          |    |  |  |
|                                       | Load Status Register and Stop                | Immediate Data - SR; STOP                                                                                                      |                               | *          |          | +  |  |  |
|                                       | Subtract Binary                              | (Destination) - (Source) - Destination                                                                                         | *                             | ŀ          | ╈        | ŀ  |  |  |
| SUBA S                                | Subtract Address                             | (Destination) - (Source) - Destination                                                                                         |                               | -          | +_       |    |  |  |
| SUBI                                  | Subtract Immediate                           | (Destination) - Immediate Data - Destination                                                                                   | +                             | *          | . 1      | 1. |  |  |
|                                       | Subtract Quick                               | (Destination) - Immediate Data - Destination                                                                                   | -                             | -          | +        | ┝  |  |  |
|                                       | Subtract with Extend                         | {Destination} – (Source) – X → Destination                                                                                     |                               | *          | ++       |    |  |  |
|                                       | Swap Register Halves                         | Register [31:16] ↔ Register [15:0]                                                                                             | ····                          | -          | ╆╸       | c  |  |  |
|                                       | lest and Set an Operand                      | (Destination) Tested $\rightarrow$ CC; 1 $\rightarrow$ [7] OF Destination                                                      |                               | -          | ÷        | ī  |  |  |
|                                       | Гар                                          | $PC \rightarrow -(SSP); SR \rightarrow -(SSP); (Vector) \rightarrow PC$                                                        |                               | -          | ┢        | -  |  |  |
|                                       | Trap on Overflow                             | If V then TRAP                                                                                                                 |                               | <u> </u>   | Ē        | -  |  |  |
| ····                                  | Test and Operand                             | (Destination) Tested → CC                                                                                                      | - <del> -</del>               | •          | +        | 0  |  |  |
| · · · · · · · · · · · · · · · · · · · | Jolink                                       | $An \rightarrow SP$ : (SP) + $\rightarrow An$                                                                                  |                               |            | $\vdash$ | -  |  |  |
|                                       |                                              | I     I= bit number       Λ     logical AND       V     logical OR       Ø logical exclusive OR       ~     logical complement | • af<br>- u<br>0 cle<br>1 set | nal<br>are | Itecl    | ec |  |  |

FIGURE 3.1 The 68000 instruction set table. (Courtesy of Motorola, Inc.)

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Source <ea>: All addr</ea>                                                                                                                                                                                                                                                                                                                      |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 000011****1*1***001101                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Destination <ea>: Modes An<br/>immedia<br/>can be u</ea>                                                                                                                                                                                                                                                                                        |
| >0001100**1=1**1***001101<br>N***11****1*1**1**1**1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Clearly, from the preceding information<br>and is a data register and the other operand of<br>the source, all addressing modes are perm<br>addressing modes are not allowed. The instru-<br>word operands.<br>Following the preceding guidelines, pr<br>tions. For example,                                                                     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ADD.L D7,D6 Add long w<br>D6, with the                                                                                                                                                                                                                                                                                                          |
| NOT<br>OR<br>OR<br>OR<br>OR<br>OR<br>OR<br>OR<br>OR<br>SEC<br>SEC<br>SUBA<br>SUBA<br>SUBA<br>SUBA<br>SUBA<br>SUBA<br>SUBA<br>SUBA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ADD.B (A5),D3 Add the byte<br>contents of<br>in D3.                                                                                                                                                                                                                                                                                             |
| 000000000000000000000000000000000000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | are valid forms of the ADD instruction. On the                                                                                                                                                                                                                                                                                                  |
| > * 0 0 1 0 1 1 1 0 0 1 * * 1 1 1 0 0 0 = * * 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ADD.W $(A5)$ , $(A2)$ Add the men $(A2)$ , with $(A2)$ .                                                                                                                                                                                                                                                                                        |
| ××××××××××××××××××××××××××××××××××××××                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ADD.B D6,#\$12 Add the by<br>\$12 and pu<br>location.                                                                                                                                                                                                                                                                                           |
| DIVU<br>BORU<br>BOR<br>ISR<br>ILEA<br>ISR<br>ILEA<br>ISR<br>MOVE<br>MOVE<br>MOVE<br>MOVE<br>MOVE<br>MOVE<br>MOVE<br>MOVE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ADD.B D6,#\$12 Add the by<br>\$12 and pullocation.<br>are invalid forms of the ADD instruction. In<br>appear as one of the operands. In the latter, the<br>by the immediate addressing mode.<br>Each instruction may have several variis<br>sider the first six instructions in the instruction<br>of the ADD instruction as shown in Figure 3. |
| U     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     **     ** <t< td=""><td></td></t<> |                                                                                                                                                                                                                                                                                                                                                 |
| × * * I * * * I I * I I I I I I I I I I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                 |
| ABCD<br>ADDA<br>ADDA<br>ADDA<br>ADDA<br>ADDA<br>ADDA<br>ADDA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | FIGURE 3.2<br>Motorola, Inc.)                                                                                                                                                                                                                                                                                                                   |

an be used.

All addressing modes permissible.

odes An, d(PC), d(PC,Rn), and mmediate are not permissible. Other modes

rmation, either the source or the destination opererand can be an effective address <ea>. If <ea> is permissible. If <ea> is the destination, some e instruction can operate on byte, word, and long-

nes, programmers can easily write valid instruc-

ong word in D7 to the long word in with the result in D6.

he byte from memory addressed by the ents of A5 to the byte in D3, with the result

. On the other hand,

he memory words addressed by (A5) and , with the result in memory addressed by

I the byte in D6 to the immediate data and put the result at the immediate data

tion. In the former case, a data register does not latter, the destination operand cannot be specified

ral variations, depending upon the operands. Construction set in Figure 3.1. They are the variations gure 3.3. The 68000 uses the same mnemonic

rands are of the BCD type.

tion operand is an address register. operand is immediate data. operand is quick data. flag (X) is included in the addition.

struction in the 68000 instruction set.

(ADD in this case), with extensions such as A, I, Q, and X, to signify the different variations. The ABCD instruction is specifically made more symbolic to represent the BCD data, but it still belongs to the same ADD category.

The 68000 follows this consistent structure for all of its instructions. These instructions can be interpreted easily and appropriate forms written for programming and the software applications.

## **The Instruction Groups**

The 68000 instructions may be broadly classified into the following groups:

- 1. data movement;
- 2. binary integer arithmetic;
- 3. BCD (binary coded decimal);
- 4. logic, shift, and rotate;
- 5. bit manipulation;
- 6. program control;
- 7. system control; and
- 8. special category for extended functions.

The data movement group deals with the physical movement of the source and destination operands. The integer, BCD, logic, shift, and rotate groups deal with the actual data processing operations. The program control group deals with the decisionmaking, conditional, and unconditional branch and jump operations. The bitmanipulation and the system control groups supplement the other operations mentioned above. We will deal with the special category in subsequent chapters.

The following example problem provides a review of the general features of the instruction set.

## Example 3.1 The 68000 instruction set.

The syntax and attributes for the ADDA and ADDI are as follows, and permissible addressing modes for the effective addresses are as specified:

| Syntax                 | Attributes            | Addressing Modes                                                                      |
|------------------------|-----------------------|---------------------------------------------------------------------------------------|
| ADDA <ea>,An:</ea>     | word, long word       | All modes allowed for source <ea>.</ea>                                               |
| ADDI #data, <ea>:</ea> | byte, word, long word | An, d(PC), d(PC,Rn), and<br>immediate modes not allowed for<br>destination <ea>.</ea> |

1. Specify whether the following four forms are valid or not. Give the reason(s):

| ADDA.L A6,A4      | ADDA.B A1,A3      |
|-------------------|-------------------|
| ADDI.W #\$12AC,D7 | ADDI.W #\$100E,A3 |

2. Specify to which groups each of the instructions belongs.

#### Solution

1. ADDA.L A6,A4: This instruction is valid since it satisfies all of the guidelines (single-word instruction).

ADDA.B A1,A3: This instruction is not valid since the byte attribute is not allowed. ADDI.W #\$12AC, D7: This instruction is valid since it satisfies all the guidelines (two-word instruction).

ADDI.W #\$100E,A3: This instruction is not valid since the destination <ea> (= A3) is not valid.

2. Group: All of the instructions are of the addition type. As such, they belong to the arithmetic group.

Any invalid instruction will generate an error condition known as an illegal instruction exception. We will discuss this exception in later chapters.

Figure 3.4 illustrates a standard convention introduced by Motorola to summarize the addressing modes, especially while dealing with the instruction set. We will use this convention in our discussion. The addressing modes are classified as data, memory, control, and alterable types. In the data type, the <ea> refers to a data operand. In the memory type, the memory reference is explicit as to where the data operand can be

| Effective Address Modes | Data | Memory | Control | Alterable |
|-------------------------|------|--------|---------|-----------|
| Da                      | Х    |        |         | Х         |
| An                      |      |        |         | х         |
| (An)                    | Х    | Х      | Х       | х         |
| (An)+                   | Х    | Х      |         | х         |
| -(An)                   | Х    | х      |         | х         |
| d <sub>16</sub> (An)    | Х    | Х      | Х       | х         |
| d <sub>8</sub> (An,Rx)  | х    | Х      | Х       | х         |
| xxxx (Absolute short)   | Х    | х      | Х       | Х         |
| xxxxxx (Absolute long)  | х    | х      | X       | Х         |
| #xxx (Immediate)        | Х    | Х      |         |           |

FIGURE 3.4 Effective address classification for the 68000. (Courtesy of Motorola, Inc.)

found. In the control type, the addressing mode can be used for program control. In the alterable type, the addressed operand may change.

A single addressing mode can be classified in more than one category.<sup>4</sup> Consider the ARI mode (An), for example. It can be classified in all four categories. It can address data, it can address memory, it can specify a jump or a branch address for program control, and the operand addressed by this mode can be allowed to change. On the other hand, the immediate (#xxx) addressing mode belongs only to the data-type category. It cannot address memory, cannot specify a jump or branch address, and it is unalterable.

# 3.2 DATA MOVEMENT AND ARITHMETIC INSTRUCTION GROUPS

Data movement is an integral part of a computer system operation. The 68000 has a very powerful and efficient group of data movement instructions, as shown in Figure 3.5. The group consists of several forms of the MOVE, EXG, and SWAP instructions. The privileged instructions are indicated with an asterisk; these should be used only in the supervisor mode.

The first column specifies the instruction in mnemonic form. The second column specifies the operand size—a byte (8 bits), a word (16 bits), or a long word (32 bits). The third and fourth columns specify the operation and the syntax (or notation). The last column specifies the allowed addressing modes. We will now interpret these entries and provide some typical illustrations from each of the groups.

## **Data Movement Instructions**

Consider the general MOVE instruction from the table in Figure 3.5. It handles byte, word, or long-word operands. Data movement is always from the source to the destination operand. The notation is MOVE <ea>,<ea>. All addressing modes are allowed for the source <ea>. Only data-alterable addressing modes, however, are allowed for the destination <ea>. Thus, any addressing mode that does not belong to both the data and the alterable types is not allowed. Referring to Figure 3.4, it can be seen that, for the MOVE instruction, the following addressing modes are not allowed for the destination effective address:

An: Not allowed, since it is not of the data type

#XXX (immediate): Not allowed, since it is not of the alterable

type

MOVE instructions dealing with the status register (SR) and the USP are privileged as indicated. The EXG (exchange) instruction exchanges the long-word contents of two of the specified internal data or address registers. Similarly, the SWAP instruction exchanges (swaps) the lower and upper words in a data register.<sup>5</sup>

| Instruction  | Operand<br>Size | Operation                                                                                              | Notation                   | Allowable<br>Effective<br>Address<br>Modes |
|--------------|-----------------|--------------------------------------------------------------------------------------------------------|----------------------------|--------------------------------------------|
| MOVE         | 8.16.32         | (SOURCE) →<br>DESTINATION                                                                              | MOVE (ea),(ea)             | SOURCE-ALI<br>DEST-DATA<br>ALTERABLE       |
| MOVE from SR | 16              | SR →<br>DESTINATION                                                                                    | MOVE SR,(ea)               | DATA<br>ALTERABLE                          |
| MOVE to CC   | 16              | $(SOURCE) \rightarrow CCR$                                                                             | MOVE (ea),CCR              | DATA                                       |
| *MOVE to SR  | 16              | (SOURCE) -→ SR                                                                                         | MOVE (ea),SR               | DATA                                       |
| *MOVE USP    | 32              | $\begin{array}{l} \text{USP} \rightarrow \text{An or} \\ \text{An} \rightarrow \text{USP} \end{array}$ | MOVE USP,An<br>MOVE An,USP |                                            |
| MOVEA        | 16,32           | (SOURCE) →<br>DESTINATION                                                                              | MOVEA (ca),An              | ALL                                        |
| MOVEQ        | 32              | IMMEDIATE DATA →<br>DESTINATION                                                                        | MOVEQ # (data),Dn          |                                            |
| EXG          | 32              | Rx ↔ Ry                                                                                                | EXG Rx,Ry                  |                                            |
| SWAP         | 16              | Dnlw ↔ Dnhw                                                                                            | SWAP Dn                    |                                            |

# FIGURE 3.5 The 68000 data movement group of instructions. (Courtesy of Motorola Inc.)

Figure 3.6 indicates the initial values of the registers and the memory. We will use these values for the examples in this chapter. In the general MOVE instruction, there is no overflow, and the C and V flags are reset to 0; the X flag is unaffected (see Appendix B for details). An example follows.

MOVE.L D1,D3

...

Move long-word data from Dl into D3. Dl (before) 12340678D3 (before) 0000008D3 (after) 12340678Only the N and Z flags are affected. The result (new data in D3) is a positive nonzero value. As such, N = 0 and Z = 0. X N Z V C (after) = 00000

|                                           | Memory Address | Word Data |
|-------------------------------------------|----------------|-----------|
| D0 = \$ 1 2 3 4 0 6 7 8                   | \$0034FE74     | 1 A B 2   |
| D1 = \$ A B C D E F 0 0                   | \$0034FE76     | 3CD4      |
| $D_1 = \phi_{112} = \phi_{12}$            | \$0034FE78     | 5EF6      |
| $D2 = \$ \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 4$     | \$0034FE7A     | 9873      |
|                                           | \$0034FE7C     | 2408      |
| D3 = \$ 0 0 0 0 0 0 0 8                   | \$0034FE7E     | 0000      |
|                                           | :              | :         |
| A0 = \$ 0 0 4 8 7 6 F 2                   | :              | CD02      |
|                                           | \$00487D6E     | 200B      |
| A1 = \$ 0 0 3 4 F E 7 8                   | \$00487D70     | 2000      |
| $A2 = \$ \ 0 \ 0 \ 0 \ 0 \ 1 \ 0 \ 0 \ 0$ |                |           |
| $A3 = \$ \ 0 \ 0 \ 0 \ 0 \ 1 \ 5 \ 0 \ 3$ |                |           |
| 1 System byte                             | User byte      |           |
| SR = \$0400 = 0000 010                    | 0 00000000     |           |
| SR = 50400 - 00000                        | I XNZVC        |           |
| 21                                        |                |           |

FIGURE 3.6 Initial values for the registers and the data operands in memory.

| EXG A0,A1 | Exchange the long-word contents of A0 and A1. The flags are<br>not affected.<br>A0 (before) $$004876F2$<br>A1 (before) $$0034FE78$<br>A0 (after) $$0034FE78$<br>A1 (after) $$0034FE78$<br>A1 (after) $$004876F2$<br>X N Z V C (after) = 00000                                                                                               |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SWAP DI   | Swap the lower and the upper words in D1.<br>D1 (before) $$A B C D E F 0 0$<br>D1 (after) $$E F 0 0 A B C D$<br>The N and Z flags are affected. C and V are reset to 0, and X is<br>unaffected. The MSB of the result is 1 ( $$E = 1110$ ) and the<br>result is a nonzero value. As such, N = 1 and Z = 0.<br>X N Z V C (after) = 0 1 0 0 0 |

We will now present an example problem to review the data movement instructions and operations.

#### Example 3.2 Data movement instructions.

In a control system application, the following software is run:

| MOVE.W (Al),D1 | ;move memory word addressed by (ftl) into Dl |
|----------------|----------------------------------------------|
| SWAP Dl        | ;swap the lower and the upper words in Dl    |
|                | ;exchange long words in Dl and D3            |
| MOVE.L D3,D7   | ;move long word in D3 into D?                |

Using the initial values of Figure 3.6, show the contents of the affected registers and the flags.

#### Solution

After the MOVE.W (A1),D1 instruction, Dl contains \$ABCD5EF6. Jhe'upper word of Dl is not affected. The data operand \$5EF6 is moved to the lower word position of the Dl register.  $\sim /$ 

After the SWAP Dl instruction, Dl contains \$5EF6ABCD.

After the EXG D1,D3 instruction, the long-word contents of the D1 and D3 registers are exchanged. D1 =\$00000008; D3 =\$5EF6ABCD.

After the MOVE.L D3,D7 instruction, both D3 and D7 contain 5EF6ABCD. The result is positive (MSD = 5 = 0101 and the MSB = 0) and is nonzero. As such, N = 0 and Z = 0. The X flag is unaffected. The C and V flags are reset to zero, since there is no overflow in the MOVE operation. The final results are

## D7 = \$ 5 E F 6 A B C D

### $\mathbf{X} \mathbf{N} \mathbf{Z} \mathbf{V} \mathbf{C} = \mathbf{0} \mathbf{0} \mathbf{0} \mathbf{0} \mathbf{0}$

**Binary Integer Arithmetic Instructions** 

These instructions deal with numbers and arithmetic operations. The 68000 processor distinguishes between signed and unsigned numbers. We will briefly discuss this concept in preparation for the discussion that follows. (Refer to Appendix A for details concerning binary and BCD numbers and arithmetic.)<sup>6</sup>

Consider a byte operand. In **unsigned operations** it represents a range of \$00 to M'F, which corresponds to decimal values 0 to 255 as shown in Figure 3.7(a). **In signed operations**, when the MSB of the operand is 0, the operand is considered to be a positive number; when the MSB is 1, the operand is considered to be a negative number. Thus, \$00 to \$7F are positive numbers (decimal values 0 to 127) and \$80 to \$FF are negative numbers (decimal values —128 to —1 in the twos-complement form), as shown in Figure 3.7(b).





Figures 3.8 and 3.9 illustrate the four categories of binary integer arithmetic instructions. They are ADD, SUBTRACT, COMPARE, and MULTIPLY and DIVIDE. All belong to the data processing group.

*Add and Subtract Instructions* There are five variations of the ADD and SUB (subtract) instructions, as shown in Figure 3.8. Except in the case of the ADDA and SUBA instructions, all five flags are affected. The C and X flags are set to 1 if there is an overflow generated from the addition operation. Similarly, the C and X flags are set to 1 if there is a borrow generated from the subtraction operation. The Z flag is set to 1 if the result of either of the operations is zero for the final operand. The N flag is set if the MSB of the result is 1. (Refer to Figure 3.2 for computation of the condition codes or flags.)

In the signed operations, the V flag is set to 1 when two positive numbers (MSB = 0 in each case) are added and a negative result (MSB = 1) is generated, or vice versa. Similarly, the V flag is set to 1 when a positive number is subtracted from a negative number and a positive result is generated, or vice versa. These conditions are known as **signed overflow.** If the signed operations are not of interest, the V flag may be ignored. An example follows using the initial values of Figure 3.6.

ADD.B #\$6F,D0Add immediate data byte \$6F to byte in D0, with the result in<br/>D0. The destination <ea> is data register direct, which be-<br/>longs to the data-alterable type.<br/>Addition = \$6F + \$78 = \$E7 = 1110 0111<br/>D0 (before) \$12340678<br/>D0 (after) \$123406E7

| Instruction | Operand<br>Size | Operation                                                | Notation                         | Allowable<br>Effective<br>Address<br>Modes |
|-------------|-----------------|----------------------------------------------------------|----------------------------------|--------------------------------------------|
| ADD         | 8,16,32         | (DESTINATION) + (SOURCE) $\rightarrow$<br>DESTINATION    | ADD Dn,(ca)                      | ALTERABLE<br>MEMORY                        |
|             |                 | DESTINATION                                              | ADD (ea),Dn                      | ALL                                        |
| ADDA        | 16,32           | (DESTINATION) + (SOURCE) $\rightarrow$ DESTINATION       | ADD (ea),An                      | Alt                                        |
| ADDI        | 8,16,32         | (DESTINATION) + IMMEDIATE DATA $\rightarrow$ DESTINATION | ADDI # (data),(ca)               | DATA<br>ALTERABLE                          |
| ADDQ        | 8,16,32         | (DESTINATION) + IMMEDIATE DATA $\rightarrow$ DESTINATION | ADDQ # (data),(ea)               | ALTERABLE                                  |
| ADDX        | 8,16,32         | (DESTINATION) + (SOURCE) + $X \rightarrow$ DESTINATION   | ADDX Dy, Dx<br>ADDX -(Ay), -(Ax) |                                            |

(a)

| Instruction | Operand<br>Size | Operation                                                | Notation                        | Allowable<br>Effective<br>Address<br>Modes |
|-------------|-----------------|----------------------------------------------------------|---------------------------------|--------------------------------------------|
| SUB         | 8,16,32         | (DESTINATION) - (SOURCE) $\rightarrow$<br>DESTINATION    | SUB Dn,(ea)                     | ALTERABLE<br>MEMORY                        |
|             |                 | DESTINATION                                              |                                 | ALL                                        |
| SUBA        | 16,32           | (DESTINATION) – (SOURCE) $\rightarrow$ DESTINATION       | SUBA (ea),An                    | ALL                                        |
| SUBI        | 8,16,32         | (DESTINATION) – IMMEDIATE DATA $\rightarrow$ DESTINATION | SUBI # (data),(ea)              | DATA<br>ALTERABLE                          |
| SUBQ        | 8,16,32         | (DESTINATION) – IMMEDIATE DATA $\rightarrow$ DESTINATION | SUBQ # (data),(ea)              | ALTERABLE                                  |
| SUBX        | 8,16,32         | (DESTINATION) – (SOURCE) – $X \rightarrow DESTINATION$   | SUBX Dy,Dx<br>SUBX -(Ay), -(Ax) |                                            |

(b)

FIGURE 3.8 Binary arithmetic instructions for the 68000. (a) Add-type; (b) subtract-type. (Courtesy of Motorola, Inc.)

|             | Operand<br>Size | Operation                                                       | Notation             | Allowable<br>Effective<br>Address Modes |
|-------------|-----------------|-----------------------------------------------------------------|----------------------|-----------------------------------------|
| Instruction | 8,16,32         | (OPERAND2) - (OPERAND1)                                         | CMP (ea),Dn          | ALL                                     |
| CMP         |                 | (OPERAND2) - (OPERAND1)                                         | CMPA (ea),An         | ALL                                     |
| CMPA        | 16,32           |                                                                 |                      | DATA                                    |
| СМРІ        | 8,16,32         | (OPERAND) – IMMEDIATE<br>DATA                                   | CMPI #(data),(ea)    | ALTERABLE                               |
| CMPM        | 8,16,32         | (OPERAND2) - (OPERAND1)                                         | CMPM $(Ay) + (Ax) +$ |                                         |
| TST         | 8,16,32         | (DESTINATION) $- 0$<br>(DESTINATION) TESTED $\rightarrow$<br>CC | TST (ea)             | DATA<br>ALTERABLE                       |

(a)

|                    | Operand<br>Size | Operation                                    | Notation     | Allowable<br>Effective<br>Address Modes |
|--------------------|-----------------|----------------------------------------------|--------------|-----------------------------------------|
| Instruction<br>EXT | 16,32           | (DESTINATION) Sign-EXTENDED →<br>DESTINATION | EXT Dn       |                                         |
| MULS               | 16              | (SOURCE)*(DESTINATION) →<br>DESTINATION      | MULS (ea),Dn | DATA                                    |
| MULU               | 16              | (SOURCE)*(DESTINATION) →<br>DESTINATION      | MULU (ea),Dn | DATA                                    |
| NEG                | 8,16,32         | 0 – (DESTINATION) →<br>DESTINATION           | NEG (ea)     | DATA<br>ALTERABLE                       |
| NEGX               | 8,16,32         | 0 – (DESTINATION) – X →<br>DESTINATION       | NEGX (ea)    | DATA<br>ALTERABLE                       |
| CLR                | 8,16,32         | $0 \rightarrow \text{DESTINATION}$           | CLR (ea)     | DATA<br>ALTERABLE                       |
| DIVS               | 16              | (DESTINATION) ÷ (SOURCE) →<br>DESTINATION    | DIVS (ea),Dn | DATA                                    |
| DIVU               | 16              | (DESTINATION) ÷ (SOURCE) →<br>DESTINATION    | DIVU (ea),Dn | DATA                                    |

**(b)** 

FIGURE 3.9 (a) Compare-type instructions for the 68000; (b) multiply, divide, and sign-related instructions. (Courtesy of Motorola, Inc.)

X and C are 0, since there is no normal overflow. The MSB of the result is 1 and the result is nonzero. As such, N = 1 and Z = 0. The V flag is set since there is an overflow of the result beyond \$7F. It is as if two positive numbers are added (\$6F and \$78) and a negative result (\$E7) obtained in signed binary operations.7

X N Z V C (after) = 0 1 0 1 0

| SUBA.W A0,A1 | Subtract the word operand in A0 from                                                                               |                           | the word operand in |
|--------------|--------------------------------------------------------------------------------------------------------------------|---------------------------|---------------------|
|              | A1, with the result in A1. All 32 bits of the destination a affected. The source word is sign extended to 32 bits. |                           |                     |
|              |                                                                                                                    |                           |                     |
|              | Contents of A                                                                                                      | \$0034FE78                |                     |
|              | Sign-extended word from A0<br>Result of subtraction in A1*                                                         |                           | \$000076F2          |
|              |                                                                                                                    |                           | \$00348786          |
|              | A1 (before)                                                                                                        | \$0034FE78                |                     |
|              | A1 (after)                                                                                                         | \$00348786                |                     |
|              | Flags are not                                                                                                      | ation <ea> is an ad-</ea> |                     |
|              | dress register.                                                                                                    |                           |                     |

\*In subtraction operations, the source subtrahend is converted into the twos-complement form and added to the destination minuend.

Compare Instructions There are five variations of the compare instruction, as indicated in Figure 3.9(a). The source operand is subtracted from the destination operand. The result is not stored, but is used to set or reset the flag bits in the condition code register (user byte of the SR). The processor uses this information to make decisions and control the program flow. The objective of the compare operation is to learn whether an operand has reached a particular value. The source and the destination operands (also called operand 1 and operand 2) are not affected in compare-type operations. Examples follow using the initial values of Figure 3.6.

1

| CMP.W D1,D0   | Compare the word in D1 with the word in D0 and set or reset   |
|---------------|---------------------------------------------------------------|
|               | the flags accordingly. (The word in D1 is subtracted from the |
|               | word in D0. The result is not stored; D0 and D1 are not af-   |
|               | fected, but the flags change.)                                |
|               | Word operand in D0 \$ 0 6 7 8                                 |
|               | Word operand in D1 \$EF00                                     |
|               | Result of the subtraction = $\frac{1778}{1778}$               |
| 1             | (borrow generated)                                            |
| ÷.            | D0 (before) \$12340678                                        |
| :             | D1 (before) $A B C D E F 0 0$                                 |
|               | D0 (after) \$ 1 2 3 4 0 6 7 8                                 |
|               | D1 (after) \$ A B C D E F 0 0                                 |
| 26 S.<br>1997 | X is not affected, but C is affected. Borrow is generated and |
|               | C = 1. Nonzero positive result (MSB = 0). As such, $N = 0$    |
|               | and $Z = 0$ . There is no signed overflow and $V = 0$ .       |
|               | X N Z V C (after) = $0\ 0\ 0\ 0\ 1$                           |
|               |                                                               |
|               |                                                               |
|               |                                                               |

| TST.B \$0007(A1) | Test the destination operand and set or reset the flags accord-<br>ingly. The tested operand is not affected. |
|------------------|---------------------------------------------------------------------------------------------------------------|
|                  | The ARI with displacement addressing mode is used for the                                                     |
|                  | destination <ea>.</ea>                                                                                        |
|                  | Contents of A1 \$ 0 0 3 4 F E 7 8                                                                             |
|                  | Sign-extended displacement <u>\$0000007</u>                                                                   |
|                  | Destination $\langle ea \rangle = $ \$ 0 0 3 4 F E 7 F                                                        |
|                  | Byte operand from $0034FE7F = 00$ . X is not affected, C =                                                    |
|                  | 0, and $V = 0$ (since there is no overflow in the test operation).                                            |
|                  | The tested destination is positive (MSB = $0$ ) and has a value                                               |
|                  | of zero. As such, $N = 0$ and $Z = 1$ .                                                                       |
|                  | X N Z V C (after) = $0\ 0\ 1\ 0\ 0$                                                                           |

The TST (test) instruction is very useful in testing the operand and providing the condition code information without modifying the tested operand.

*Multiply, Divide, and Sign-related instructions* These instructions are presented in Figure 3.9(b). The EXT instruction sign extends a byte to a word (EXT.W) or a word to a long word (EXT.L). The objective of this instruction is to increase the size of the operand without changing its arithmetic value. Some instructions (ADD, SUB, for example) require that both operands be of the same size for computations. The EXT instruction is used in such instances. Notice that the operand should be contained in one of the data registers Dn.

The NEG instruction negates the operand. It subtracts the destination operand from \$0 and puts the result back in the destination location. In effect, it performs a twoscomplement operation on the operand. The NEGX instruction includes the X flag in the computation. Data-alterable addressing modes are allowed for NEG and NEGX instructions. Examples follow using the initial values of Figure 3.6.

| EXT.Ł DI | Sign extend the word operand in D1 to a long word. The word oper-<br>and in D1 = $E F 0 0$ . The MSB = 1 (since MSD $E = 1 1 1 0$ )<br>and the operand is considered negative. This MSB is replicated to all<br>the higher bits in the D1 register.<br>D1 (before) $A B C D E F 0 0$<br>D1 (after) $F F F F E F 0 0$<br>D1 (after) $F F F F E F 0 0$<br>D1 has the same numeric value as it did before, but the size of D1 is<br>increased to a long word. X is not affected, $C = 0$ , and $V = 0$ . The<br>resulting operand is negative (MSB = 1) and nonzero. As such, N =<br>1 and Z = 0.<br>X N Z V C (after) = 0 1 0 0 0 |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NEG.B D2 | Negate the byte operand in D2. Subtract the byte operand in D2 from \$00 and put the result back in D2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

NECE B D2 Negate the officiency of the result back in D2. S00 and put the result back in D2. Value to be subtracted from \$ 0 0Byte operand in D2  $\frac{\$ 0 4}{\$ FC}$ (borrow generated) D2 (before) \$ 0 0 0 0 0 0 4D2 (after) \$ 0 0 0 0 0 0 F CAll the flags are affected. Borrow is generated: C = 1 and X = 1. The resulting operand (\$FC) is negative (MSB = 1) and nonzero. As such, N = 1 and Z = 0. Signed overflow is not generated and V = 0. X N Z V C (after) = 1 1 0 0 1

The MULS and MULU are the signed and the unsigned multiply instructions, respectively. In the signed operations, the operands are considered to be signed binary integers. On the other hand, in the unsigned operations, the operands are considered to be unsigned binary integers. Similarly, the DIVS and DIVU are the signed and unsigned division operations, respectively. In the multiply and divide operations, the destination is always a data register Dn. In the multiply operations, the 16-bit source operand (S16) and the lower 16 bits of the destination Dn (D16) are multiplied, and the 32-bit product is transferred to the 32-bit destination Dn register (D32). Examples follow using the initial values of Figure 3.6.

| MULU D2,D3   | Multiply the word operands from sult in D3. The operands are un                                                                      |                               | , with the 32-bit | t re- |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|-------------------|-------|
|              | Multiplicand in D2 (before)                                                                                                          | \$000000                      | 004               |       |
|              | Multiplier in D3 (before)                                                                                                            | \$000000                      | 0 8 0 0           |       |
|              | D2 (after)                                                                                                                           | \$000000                      | 004               |       |
|              | Product in D3 (after)                                                                                                                | \$000000                      | ) 2 0             |       |
|              | $$4 \times $8 = $20 = 32$ decimal v<br>affected. X is unaffected. C =<br>tive (MSB = 0) and is nonzero<br>X N Z V C (after) = \$0000 | 0 and $V = 0$ .<br>As such, N | The result is p   | osi-  |
| MULS #\$2,D1 | Multiply the signed 16-bit opera<br>and (\$0002), with the 32-bit sig                                                                |                               |                   | per-  |
|              | Multiplicand word in D1 (before                                                                                                      | e) \$                         | E F 0 0           | /     |
|              | Multiplier source operand                                                                                                            | \$                            | 0002              | 1     |
|              | Sign-extended product* =                                                                                                             | \$ F F F                      | FDE00             |       |

\*\$EF00  $\times$  \$0002 results in hex string \$1DE00. Sign extending the MSB = 1 to the higher bits results in the sign-extended product \$FFFFDE00.

In the division operations, the dividend is contained in a 32-bit destination data register Dn. The divisor is the 16-bit source operand, specified by one of the data-type addressing modes. The dividend is divided by the divisor. The 16-bit quotient and the 16-bit remainder are placed in the destination data register, as shown:



| An example follows. | the interview of the lo-                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     | Divide the 32-bit dividend in the D3 destination register by the 16-<br>bit divisor in the source D2 register. Place the results as shown in<br>the preceding diagram. The operands are unsigned.<br>32-bit dividend operand in D3 (before) = $\$ 0000008$<br>16-bit divisor operand in D2 (before) = $\$ 00004$<br>Upon dividing, the 16-bit quotient = $\$00002$<br>the 16-bit remainder = $\$000002$<br>The N, Z, and V flags are affected. X is unaffected and C = 0.<br>The quotient is positive (MSB = 0) and nonzero. As such, N = 0<br>and Z = 0. There is no division overflow and V = 0.<br>X N Z V C (after) = $00000$<br>Note: If the divisor is zero, the zero divide exception occurs. |

# BCD (Binary Coded Decimal) Instructions

The three BCD instructions are presented in Figure 3.10. The operand size is byte. The X flag is always involved in the computations. The ABCD (add BCD) and the \$SBCD (subtract BCD) instructions use only the data register direct (Dn) or the ARI with predecrement (-(An)) addressing modes for both the source and the destination operands. This provides an easy and reliable access to the operands in a low-to-high value sequence, which is required for BCD arithmetic. The NBCD (negate BCD) is similar to the binary NEGX instruction. All the data-alterable addressing modes are allowed for the NBCD instruction. Only the X, Z and C flags are affected for the BCD instructions.<sup>8</sup> An example follows using the initial values of Figure 3.6.

| Instruction | Operand<br>Syntax             | Operand<br>Size | Operation                                                                      |
|-------------|-------------------------------|-----------------|--------------------------------------------------------------------------------|
| ABCD        | $\frac{Dn, Dn}{-(An), -(An)}$ | 8<br>8          | Source <sub>10</sub> + Destination <sub>10</sub> + $X \rightarrow$ Destination |
| NBCD        | (ea)                          | 8               | $0 - \text{Destination}_{10} - X - \rightarrow \text{Destination}$             |
| SBCD        | Dn, Dn<br>-(An), -(An)        | 8<br>8          | Destination <sub>10</sub> – Source <sub>10</sub> – $X \rightarrow$ Destination |

## FIGURE 3.10 BCD instructions.

Add the BCD byte operand in D0 to the BCD byte operand in D3, ABCD D0,D3 with the result in D3. Source BCD byte in D0 (before) 78 Destination BCD byte in D3 (before) 0.8 = 86 Result of the BCD addition

D0 (before) 12340678 D3 (before) 0000008 D0 (after) 12340678 D3 (after) 0000086 There is no overflow and the result is nonzero. As such, X N Z V C (after) = 0 0 0 0 0

In BCD operations, the operands are expected to be of the BCD type. Any other data type generates an error condition known as the illegal instruction exception.

We will now present an example problem to review the binary and BCD arithmetic operations.

#### Example 3.3 Binary and BCD operations using the 68000.

In a digital signal processing application, the following software is written as a subroutine:

ADD.W #\$0004,D0;add immediate data \$4 to the word in D0 ;multiply words in D2 and D0 with result in D0 MULS D2,DD subtract quick data & from long word in DO SUBQ.L #\$O&,DO ;divide long word in DD with word in D1 DIVU D1,D0 return from subroutine RTS

Consider the initial values

S

$$D0 = $12340678; D1 = $00000006; D2 = $00000004 \\ SR = $0405 = 0000 0100 0000 0101 \\ X N Z V C$$

- 1. What are the values of the affected registers and the SR at the end of the subroutine?
- 2. If [SUBQ.L #\$08,D0] is changed to [SUBQ.L #\$80,D0], will the software be functional? Why or why not?

#### Solution

1. Results of the software: After the addition, the destination register D0 =\$1234067C. Signed multiplication of words in D2 (= 0004) and D0 (= 007C) results in a 32-bit product in D0 (= \$000019F0), as shown:

| Overflow generated                  |         |
|-------------------------------------|---------|
| (see note)                          | 113     |
| \$ Multiplicand =                   | 067C    |
| \$ Multiplier =                     | 0004    |
| ign-extended 32-bit product = $\$0$ | 00019F0 |

Note: C = 12 decimal;  $4 \times C = 4 \times 12 = 48$ , which is equal to \$30. Digit \$3 is the hex overflow to the next hex position. The hex multiplication proceeds in this fashion.

10 + 0 = 6632

After the subtraction, the destination register D0 =\$000019E8. Unsigned division of the dividend in D0 (= 000019E8) by the divisor in D1 (= 0006) is as shown, using the hex-to-decimal and decimal-to-hex conversions. (E = 14.)

Dividend 
$$000019E8 = (1 \times 16^3) + (9 \times 16^2) + (14 \times 16) + 8 - 0032$$

Divisor 0006 = 6. The decimal division results in

$$\frac{6632}{6} = 1105$$
 quotient, with 2 as a remainder

Converting the decimal quotient 1105 into hex, we obtain

Quotient 
$$1105 = (4 \times 16^2) + (5 \times 16) + 1 = $451$$

Remainder 2 =\$2.

The remainder and the quotient are put into the destination D0 as the higher and lower words, and D0 = \$00020451. The quotient (\$0451) is positive and nonzero and there is no division overflow. As such, the flag bits N = 0, Z = 0, and

V = 0. The X flag is unaffected and the C flag is reset to zero. The RTS instruction causes the processor to return to the calling program. The flag register is unaffected by the RTS and contains the information relating to the

instruction before the RTS.

The final results are

D0 = \$ 0 0 0 2 0 4 5 10400 SR =

2. SUBQ.L #\$80,D0: The software will not be functional. The source operand #\$80 is beyond the allowed value (= \$08) for the SUBQ instruction. An error condition will be generated.

Large numeric strings of data are also easily handled by the 68000 processor. The numeric string of data resides in the memory. The processor obtains the appropriately sized data from the numeric string in the memory, performs the required operations, and stores the result in the memory. We will deal with these operations when we discuss software designs; they are known as the multiprecision arithmetic operations.

# 3.3 LOGICAL AND BIT-MANIPULATION INSTRUCTION GROUPS

The logical instructions perform the logic, shift, and rotate operations. The bitmanipulation instructions deal with the individual bits of the operands. These two groups provide the 68000 with additional data processing and control capability.

#### Logic, Shift, and Rotate instructions

The basic logic instructions are presented in Figure 3.11. They are the AND, OR, EOR (exclusive OR), and the NOT instructions. They operate on the byte, word, and longword operands. Consider the two forms of the AND instruction:

Either the source or the destination operand has to be in one of the data registers. If the source operand is in a data register, the destination <ea> is of the memory-alterable type. If the destination operand is in a data register, the source  $\langle ea \rangle$  is of the data type. In the other variation of the AND instruction:

the source operand is the immediate data and the destination <ea> is of the data-alterable type. In all of these cases, the processor performs the AND operation between the corresponding bits of the source and the destination operands, with the result in the destination. If the destination <ea> is the SR, then it is a privileged instruction. The logic instructions affect only the N and Z flags. The N flag is set to 1 if the MSB of the result is 1 (negative number). The Z flag is set to 1 if the result is 0. There is no overflow in the logical operations; as such, the C and the V flags are always reset to 0. The X flag is not affected. However, if the operand is either the SR (status register) or the CCR (condition code register), all five flag bits are affected. The OR and the EOR instructions follow the same structure as the AND, but they perform the OR and the exclusive OR operations between the corresponding bits of the source and the destination operands, with the result in the destination. The NOT instruction performs logical inversion (ones-complement form) of the operand. The operand is specified by the data-alterable type addressing modes.

The shift and rotate instructions are presented in Figure 3.12. They are the ASL and ASR (arithmetic shift left and right), LSL and LSR (logical shift left and right), ROL and ROR (rotate left and right), and ROXL and ROXR (rotate left and right through the X (lag). Consider the three forms of the ASL instruction:

The first two forms operate on byte, word, or long-word data operands. The destination operand is in one of the data registers. The destination operand is shifted left the number of times specified by the source operand. The shifted-out MSB goes into the C and X flag bits and 0 is shifted into the LSB for each shift operation. When the source operand is a data register, it can specify a shift number up to 64 (modulo 64). However, a shift count of 32 is sufficient to completely shift zeros into the register. When the source operand is a data clement, the shift count is limited to 8. When an operand is shifted left

AND Dn, <ea> AND <ea>.Dn

ANDI # <data>,<ea>

ASL Dx.Dy ASL #<data>,Dy ASL <ea>

|                                       |                                                 | Motorola, Inc.)    | The 68000 logic group of instructions. (Courtesy of Motorola, Inc.) | The 680         | FIGURE 3.11 |
|---------------------------------------|-------------------------------------------------|--------------------|---------------------------------------------------------------------|-----------------|-------------|
|                                       | DATA ALTERABLE<br>OR CCR OR<br>*STATUS REGISTER | ORI # (data),(ca)  | IMMEDIATE DATA √<br>(DESTINATION) →DESTINATION                      | 8,16,32         | ORI         |
| i                                     | DATA                                            | OR (ea),Dn         | DESTINATION                                                         |                 | 5           |
| Ţ                                     | ALTERABLE<br>MEMORY                             | OR Dn.(ea)         | (SOURCE) ∨ (DESTINATION) →                                          | 8 16 32         | ę           |
| <u> </u>                              | DATA<br>ALTERABLE                               | NOT (ca)           | (DESTINATION) →DESTINATION                                          | 8,16,32         | NOT         |
|                                       | DATA ALTERABLE<br>OR CCR OR<br>*STATUS REGISTER | EORI # (data),(ea) | IMMEDIATE DATA ⊕ (DESTINATION)<br>→DESTINATION                      | 8,16,32         | EORI        |
| <u> </u>                              | DATA<br>ALTERABLE                               | EOR Dn, (ea)       | (SOURCE) ⊕ (DESTINATION) →<br>DESTINATION                           | 8,16,32         | EOR         |
| · · · · · · · · · · · · · · · · · · · | DATA ALTERABLE<br>OR CCR OR<br>*STATUS REGISTER | ANDI # (data),(ca) | IMMEDIATE DATA ∧ (DESTINATION)<br>→DESTINATION                      | 8,16,32         | ANDI        |
|                                       | DATA                                            | AND (ea),Dn        |                                                                     | 0,10,02         |             |
| ,                                     | ALTERABLE<br>MEMORY                             | AND Dn, (ea)       | (SOURCE) ∧ (DESTINATION)                                            | 8 1K 37         |             |
|                                       | Allowable<br>Effective<br>Address Modes         | Notation           | Operation                                                           | Operand<br>Size | Instruction |

| ALLOWABLE<br>EFFECTIVE<br>ADDRESS<br>MODES | 1                   |            | MEMORY<br>ALTERABLE | i          | 1<br>1                | MEMORY     |
|--------------------------------------------|---------------------|------------|---------------------|------------|-----------------------|------------|
| NOTATION                                   | ASd Dx, Dy          |            | ASd < ea >          | LSd Dx, Dy |                       | LSd < ea > |
| OPERATION                                  | ASL C + OPERAND - O |            | ASR                 |            |                       |            |
| OPERAND<br>SIZE                            | 0 15 27             | 16         |                     |            | <u>\$,16,32</u><br>16 |            |
| INSTRUCTION                                |                     | ASL<br>ASR |                     |            | LSL                   |            |



FIGURE 3.12 The 68000 shift and rotate instructions. (Courtesy of Motorola, Inc.)

once, it amounts to multiplying the operand by 2. Thus, shifting left by 8 positions amounts to multiplying by  $256: 2^8 = 256$ .

For the third form of the ASL instruction, the operand is in memory and is specified by the memory-alterable addressing modes. The operand size is a word and is shifted once to the left.

The ASR instruction is similar to the ASL, but shifts the operand in the right direction. The MSB is shifted back into itself to preserve the sign bit of the operand. The shifted-out LSB goes into the C and X bits.

In the arithmetic shift operations, the value and the sign bit of the operand can change. Furthermore, overflow can occur. As such, all five flags are affected.

The LSL and the LSR instructions are similar to the ASL and the ASR instructions. However, in case of the LSR instruction, 0 is shifted into the MSB of the operand and the LSB is shifted out for each shift. This amounts to dividing the operand by 2.

In case of the ROL instruction, the destination operand is rotated left the number of times specified by the source operand. The MSB goes into the C flag and into the LSB position, as shown in Figure 3.12. The ROR instruction is similar to the ROL, but rotates the operand in the right direction. The ROXL and the ROXR instructions are similar to the ROL and ROR instructions, but the former pair rotate the operands through the X flag.

In the logical shift operations (LSL and LSR), and in the rotate operations through the X flag (ROXL and ROXR), the signed overflow concept is not required. As such, the V flag is reset to 0 and the other four flags are affected. Ir» the normal rotate operations (ROL and ROR), the X flag is not affected and the V flag is reset to 0. Only the other three flags are affected.

The following example problem provides a review of the logical operations.

**Example 3.4 Logical operations.** The initial values of the registers and the operands are as follows:

| D0 = \$ 1 2 3 4 0 6 7 8 | D2 = \$ 0 0 0 0 0 0 0 4 |
|-------------------------|-------------------------|
| A1 = \$0034FE78         | X N Z V C = 00000       |

| Use the same initial condition | s each time. Show the results | of the following operations: |
|--------------------------------|-------------------------------|------------------------------|
|                                | 2. ORI.B #\$F0,D0             | 3. EORI.B #\$F0,D0           |
| 1. ANDI.B #\$F0,D0             | 5. ASL.B #\$2,D0              | 6. ASR.B #\$2,D0             |
| 4. NOT.B D0                    |                               | 9. ORI.B #\$1F,CCR           |
| 7. ROL.B #\$2,D0               | 8. ROXR.B #\$2,D0             | 9, OKI.B #\$11,COR           |

#### Solution

Destination byte operand in  $D0 = $78 = 0 \ 1 \ 1 \ 1 \ 1 \ 0 \ 0 \ 0$ Source operand =  $$F0 = 1 \ 1 \ 1 \ 1 \ 0 \ 0 \ 0$  1. ANDI.B #\$F0,D0: If both the source and destination bits are 1, the result bit is 1:

2. ORI.B #\$F0,D0: If any of the source or destination bits is 1, the result bit is 1:

Result =  $1 \ 1 \ 1 \ 1 \ 1 \ 0 \ 0 \ 0$ Nonzero result and MSB =  $1 \ X \ N \ Z \ V \ C = 0 \ 1 \ 0 \ 0 \ 0$ 

3. EORI.B #\$F0,D0: If either the source or the destination bit is 1, but not both, the result bit is 1:

 $Result = 1 \ 0 \ 0 \ 1 \ 0 \ 0 0$ Nonzero result and MSB = 1 X N Z V C = 0 1 0 0 0

4. NOT.B D0: The operand bits are inverted:

Result =  $1\ 0\ 0\ 0\ 1\ 1\ 1$ Nonzero result and MSB =  $1\ X\ N\ Z\ V\ C = 0\ 1\ 0\ 0\ 0$ 

5. ASL.B #\$2,D0: The operand is shifted left twice:

 $Result = 1 \ 1 \ 1 \ 0 \ 0 \ 0 \ 0$ Nonzero result and MSB = 1 X N Z V C = 1 1 0 1 1 Last MSB shifted out = 1: (C and X = 1) Sign (MSB) changed at least once: (V = 1)

6. ASR.B #\$2,D0: The operand is shifted right twice:

 $\label{eq:Result} \begin{array}{ccc} Result = 0 \ 0 \ 0 \ 1 \ 1 \ 1 \ 1 \ 0 \\ Nonzero \ result \ and \ MSB = 0 \qquad X \ N \ Z \ V \ C = \qquad 0 \ 0 \ 0 \ 0 \ 0 \\ Last \ LSB \ shifted \ out = 0: \ (C \ and \ X = 0) \\ Sign \ (MSB) \ did \ not \ change: \ (V = 0) \end{array}$ 

7. ROL.B #\$2,D0: The operand is rotated left twice:

 Result =  $1 \ 1 \ 1 \ 0 \ 0 \ 0 \ 1$  

 Nonzero result and MSB = 1 X N Z V C =
 0  $1 \ 0 \ 0 \ 1$  

 Last MSB rotated = 1: (C = 1) X N Z V C =
 0  $1 \ 0 \ 0 \ 1$ 

8. ROXR.B #\$2,D0: The operand is rotated right twice through X:

Result =  $0\ 0\ 0\ 1\ 1\ 1\ 0$ Nonzero result and MSB = 0 X N Z V C = 00000 Last LSB rotated = 0: (C and X = 0)

Note: In each of the preceding cases, the result is put back in the byte position in the D0 destination register.

9. ORI.B #\$1F,CCR: The OR immediate operand \$1F = 00011111 with the CCR:

Result =  $0\ 0\ 0\ 1\ 1\ 1\ 1\ 1$ X N Z V C =11111 All five flags are set

The AND operation forces a 0 value to the selected bits in an operand. This is called masking. The OR operation forces a 1 value to the selected bits in an operand. The EXOR operation selectively inverts and checks the bits in an operand.

Shift and rotate operations are suitable in data processing and logical data manipulation applications. In all cases, the operand is a complete data element. In several instances, bit-level data manipulation is required.<sup>9</sup>

The MC68000 has bit-manipulation instructions with which to handle bit-level operations more efficiently. We will now discuss these instructions.

#### **Bit-Manipulation Instructions**

The bit-manipulation group of instructions are presented in Figure 3.13. They are the BCHG (bit change), BCLR (bit clear), BSET (bit set), and BTST (bit test) instructions. In each case, the source operand specifies the bit number in a destination operand.<sup>10</sup>

With all four instructions, the specified bit is first tested and the Z flag is set or reset accordingly (Z = 1 if the tested bit is 0, and vice versa). This helps the programmer to identify the bit condition before any further bit manipulation. Only the Z flag bit is affected in this group.

The BCHG instruction changes the logic value of the tested bit from 0 to 1, or vice versa. The BCLR instruction clears the specified bit. The BSET instruction sets the specified bit. The BTST instruction tests only the specified bit.

If the destination is a data register, then any of the 32 bits can be manipulated (modulo 32), as specified by the source operand. On the other hand, if the destination is a memory location, then the bit operations are restricted to 8 bits (or a byte). The destination <ea> can be specified by the data-alterable addressing modes. The source operand can either be a data register or an immediate data element. The word-sized operands are not supported in this group of instructions. In control and I/O type of applications, bit-manipulation operations are very common.

The following example will help to clarify the bit-manipulation instructions.

| Instruction | Operand<br>Size* | Operation                                                                                                                                                  | Notation                           | Allowable<br>Effect.ve<br>Address Modes |
|-------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|-----------------------------------------|
| BCHG        | 8,32             | <ul> <li>~(bit number OF</li> <li>Destination) → Z</li> <li>~(bit number OF</li> <li>Destination)</li> <li>→ bit number OF</li> <li>Destination</li> </ul> | BCHG Dn (ea)<br>BCHG # (data),(ea) | DATA<br>ALTERABLE                       |
|             | _,               | ~(bit number OF                                                                                                                                            |                                    |                                         |
|             |                  | Destination) $\rightarrow Z$                                                                                                                               | BCLR Dn, (ea)                      |                                         |
| BCLR        | 8,32             | $0 \rightarrow \text{bit number OF}$<br>Destination                                                                                                        | BCLR # (data),(ea)                 | DATA<br>ALTERABLE                       |
|             |                  | ~(bit number OF<br>Destination)                                                                                                                            | BSET Dn,(ea)                       |                                         |
| BSET        | 8,32             | $\rightarrow$ Z: 1 $\rightarrow$ bit number<br>OF Destination                                                                                              | BSET # (data),(ea)                 | DATA<br>ALTERABLE                       |
|             |                  |                                                                                                                                                            | BTST (Dn),(ea)                     | DATA                                    |
| BTST        | 8,32             | ~(bit number OF Destination) $\rightarrow Z$                                                                                                               | BTST # (data),(ea)                 | (EXCLUDING<br>IMMEDIATE)                |

\*1. For memory operation, the data size is byte.

2. For data register operation, the data size is long word.

FIGURE 3.13 The 68000 bit-manipulation instructions. (Courtesy of Motorola, Inc.)

#### Example 3.5 Bit manipulations.

The initial conditions of the registers and the operands are as follows:

D0 =\$ 1 2 3 4 0 6 7 8 D1 =\$ A B C D E F 0 0 X N Z V C = 00000

It is required to test bit 0, set bit 4, clear bit 6, and change bit 31 of the operand contained in the DO register, in the sequence stated.

- 1. Write a series of bit-manipulation instructions to perform this task.
- 2. What are the contents of the DO register and the flags after the task has been completed?
- 3. If bit-manipulation instructions are not available, what alternate software approach may be used to accomplish the task?

#### Solution

**1.** Bit-manipulation instructions: Figure 3.14(a) shows the binary (bit) representation in the DO register. Figure 3.14(b) shows a series of four bit-manipulation instructions to accomplish the task. In all of these operations only the Z flag is affected as indicated. The BTST instruction tests bit 0 of the DO register, which is a zero. As such, the Z flag is set to 1. The BSET instruction tests bit 2, which is a zero, sets the Z flag to 1, and finally sets the tested bit to 1. The BCLR instruction tests bit 6, which is a one, resets the Z flag to 0 (since the tested bit is 1), and finally clears the tested bit to 0.

The BCHG instruction tests bit 31, which is a zero; sets the Z flag to 1; and inverts the tested bit to 1. Thus, at the end of the instruction sequence, the DO register contains:

$$b31-b28 = 1 \ 0 \ 0 \ 1 = \$9$$
  
 $b27-b8 \ (no \ change) = \$23406$   
 $b7-b0 = 0 \ 0 \ 1 \ 1 \ 0 \ 1 \ 0 \ 0 = \$34$ 

#### 2. Contents of D0 and the flags: The final results are

D0 = \$92340634X N Z V C = 00100



(b)

FIGURE 3.14 (a) Binary representation for the data in D0 and (b) sequence of instructions (for Example 3.5).

# ditional sequence of instructions.

In addition to data movement, arithmetic, logical, and bit-manipulation instructions, program and system control instructions are required for implementing software programs using the 68000. We will now discuss these instructions.

## 3.4 PROGRAM AND SYSTEM CONTROL INSTRUCTION GROUPS

In programming applications, it is often necessary to change the program flow conditionally or unconditionally. It is also occasionally required to stop the processor until an external event such as an interrupt occurs. In addition, it may be necessary to reset the system I/O resources under software control. The 68000 processor has appropriate program and system control instructions to support these actions.<sup>11</sup>

## Program Control Instructions

The general program and system control instructions are presented in Figure 3.15. These instructions, all of which support program flow, are classified into three types as follows:

| 1. branch type: | Bcc: Branch on co<br>BRA: Uncondition                   |
|-----------------|---------------------------------------------------------|
|                 | BSR: Branch to s                                        |
| 2. jump type:   | JMP: Uncondition<br>JSR: Jump to sub                    |
| 3. return type: | RTE: Return from<br>RTR: Return and<br>RTS: Return from |

the next instruction is available. The <ea> is specified by the program counter relative addressing mode (d(PC)). The displacement is specified as a part of the instruction. If the displacement is 8 bits (d8), it is a short branch operation with a 256-byte range (-128 to +127). If the displacement is 16 bits (dl6), it is a long branch operation with a 64kilobyte range (-32 to +32 kilobytes). The displacement is added to the contents of the program counter (PC) to obtain the effective address. (Recall that the PC is incremented by two after fetching the op.word; this value should be used in the computation of the <ea> in all branch operations.)

Conditional branch instructions (Bcc) may or may not perform a desired function, depending on the current value of the processor's condition codes (or flags). Branching occurs if the specified condition is met, causing a change in the program

3. Alternate software: Logic and compare instructions must be used, involving an ad-

Branch-Type Instructions These instructions refer to an effective address <ea>, where

- condition onal branch subroutine nal jump proutine m exception restore
- m subroutine

| Instruction | Operand<br>Size | Operation                                                  | Notation     | Allowable<br>Effective<br>Address<br>Modes |
|-------------|-----------------|------------------------------------------------------------|--------------|--------------------------------------------|
| Bec         | 8,16            | If cc then PC + $d \rightarrow PC$ ;<br>else proceed       | Bcc(Iabel)   | PC REL                                     |
| BRA         | 8,16            | $PC + d \rightarrow PC$                                    | BRA (label)  | PC REL                                     |
| BSR         | 8,16            | $PC \rightarrow -(SP); PC + d \rightarrow PC$              | BSR (label)  | PC REL                                     |
| JMP         |                 | DESTINATION $\rightarrow$ PC                               | JMP (ea)     | CONTROL                                    |
| JSR         |                 | $PC \rightarrow -(SP); DESTINATION \rightarrow PC$         | JSR (ea)     | CONTROL                                    |
| NOP         | <u> </u>        | $PC + 2 \rightarrow PC$                                    | NOP          |                                            |
| *RESET      |                 | RESET EXTERNAL DEVICES                                     | RESET        |                                            |
| *RTE        |                 | $(SP) + \rightarrow SR;(SP) + \rightarrow PC$              | RTE          |                                            |
| RTR         |                 | $(SP) + \rightarrow CC; (SP) + \rightarrow PC$             | RTR          | _                                          |
| RTS         |                 | $(SP) + \rightarrow PC$                                    | RTS          |                                            |
| *STOP       | 16              | IMMEDIATE DATA $\rightarrow$ SR;<br>STOP PROGRAM EXECUTION | STOP #(data) |                                            |

FIGURE 3.16 Conditional branch instructions for the 68000. (Courtesy of Motorola, Inc.)

CC с CS ca EQ ec GE gr GT g HI hi LE le

> LS LT MI ŇĖ PL VC VS

routine. The branch instructions generate relocatable code, since they belong to the PC relative addressing mode. Three examples of branch-type instructions follow.

#### Instruction

PC

tion is as follows: PC value\*

PC (after)

PC Instruction

001316 BSR \$F0(PC) Branch to the subroutine at the <ea>. The <ea> computation of the subroutine at the <ea>. The <ea> computation of the subroutine at the <ea> computation of the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine at the subroutine tion is as follows: Incremented PC value = \$ 0 0 1 3 1 8 8-bit signed displacement = \$ F F F F F 0 (twos-complement form)\*  $\langle ea \rangle =$ \$ 0 0 1 3 0 8

\*Privileged

| Instruction | Operand<br>Size | Operation                                    | Notation        |
|-------------|-----------------|----------------------------------------------|-----------------|
| TRAP        |                 | PC→ $-(SSP)$ ; SR→ $-(SSP)$ ;<br>(VECTOR)→PC | TRAP #(\$0-\$F) |
| TRAPV       |                 | If V then TRAP;<br>else proceed              | TRAPV           |

FIGURE 3.15 Program control instructions for the 68000. (Courtesy of Motorola, Inc.)

flow. Otherwise, the program flow remains unchanged, and the program continues with the next sequential instruction. The different forms of the Bcc instruction are indicated in Figure 3.16.

The BRA instruction causes an unconditional branch to the specified effective address. The BSR instruction stores the PC on the stack and branches to the specified sub-

| carry clear      | 0100 | ō                                                                                   |
|------------------|------|-------------------------------------------------------------------------------------|
| carry set        | 0101 | С                                                                                   |
| equal            | 0111 | Z                                                                                   |
| greater or equal | 1100 | $N \cdot V + \overline{N} \cdot \overline{V}$                                       |
| greater than     | 1110 | $N \cdot V \cdot \overline{Z} + \overline{N} \cdot \overline{V} \cdot \overline{Z}$ |
| nigh             | 0010 | Ē·Ī                                                                                 |
| less or equal    | 1111 | $Z + N \cdot \overline{V} + \overline{N} \cdot V$                                   |
|                  |      |                                                                                     |

|--|

\$001000 BRA \$0200(PC) Unconditional branch to the <ea>. The <ea> computa-

= \$ 0 0 1 0 0 2 16-bit signed displacement =  $\frac{0200}{0200}$ <ea> =\$ 0 0 1 2 0 2 \*PC advances by two after fetching the op.word for the BRA instruction, thus pointing to \$001002. The  $\langle ea \rangle$  is loaded into the PC. PC (before) \$001002 \$001202 The processor branches to \$001202 and executes the pro-

gram starting at that location. This is a long branch, since the displacement is 16 bits.

The original PC value (= \$001318) is stored on the stack and the  $\langle ea \rangle$  (= \$001308) is loaded into the PC. The processor branches to the subroutine at \$001308. This is a short branch, since the displacement is 8 bits. \*\$F0 in twos-complement form is a negative number (= -\$10). The displacement is a negative value.

#### Instruction PC

\$001362 BNE \$06(PC) Branch, if not equal to zero, to the <ea>. This is a conditional branch instruction. If the operand from the previous operation is not equal to 0, the program branches to <ea>; otherwise it proceeds to the next sequential instruction.  $\langle ea \rangle = PC$  value + displacement

= \$001364 + \$06 = \$00136A

Some assemblers support explicit extensions to distinguish between short and long branches and jumps. We will discuss these features in the next chapter when we deal \ with assemblers and assembly programming techniques.

Jump-Type Instructions The JMP (jump) and the JSR (jump to subroutine) instructions are similar to the BRA and BSR instructions. However, in the case of the JMP and JSR, the <ea> can be specified by any one of the control addressing modes as well as by the PC relative modes.

**Return-Type Instructions** The RTE (return from exception) is the last instruction to be used in an exception service routine. It restores the registers (PC, SR) that were stored on the stack when the exception occurred, and returns to the program that was being executed at the time of the exception. RTE is a privileged instruction. RTR (return and restore) is similar to RTE, but RTR restores only the user byte (or the CCR) from the stack rather than the complete SR.

The RTS (return from subroutine) is the last instruction to be used in any subroutine service routines. It restores the PC that was stored on the stack when the subroutine call was made and returns to the calling program.

#### System Control Instructions

These instructions control and coordinate system operation. The RESET instruction generates a reset pulse on the reset pin of the processor. In system control applications, this pulse is used to reset the I/O and the peripheral devices. The STOP instruction initializes the status register with the specified data element and stops the processor operation. The processor resumes its operation when a hardware interrupt or reset occurs. The RESET and the STOP instructions are privileged.

The NOP (no operation) instruction does not perform any task; rather, it advances the PC to the next instruction location. Software engineers and programmers use NOP instructions to fill sections of the program memory for short delays and for later replacement by active instructions.

The ILLEGAL instruction corresponds to an op.word \$4AFC. It causes an illegal . instruction error exception. This exception simulates the illegal error condition in the development of the operating system software. The following example problem provides a review of the program and system control group of instructions.

**Example 3.6** Program and system control instructions. Figure 3.17 illustrates 68000-based software in an industrial application. The system is in the supervisor mode and the SR contains \$2400 initially (all the flags are zero).

- 1. What does the main program accomplish?
- 2. What does the subroutine accomplish?

#### Solution

- 1. Main program: It initializes DO with a data word \$0008 and calls a subroutine at \$00001030. After the program returns from the subroutine, it generates a reset pulse and stops the processor. When an external event such as an interrupt occurs, the program advances to the JMP instruction, which makes the program jump back to \$00001000 (start).
- 2. Subroutine: This is a delay loop. It decrements the word in DO by 1. If DO is not decremented to 0, the BNE instruction causes the program to branch back to \$00001030, which is the beginning of the delay loop. The loop is terminated when the DO register is decremented to 0, and the program advances to the RTS instruction. The RTS causes the processor to return to the main program. For the values indicated, the delay loop runs seven times and exits the eighth time.

| Main program                                                       |                             |                                   |
|--------------------------------------------------------------------|-----------------------------|-----------------------------------|
| PC                                                                 | Instruction                 | n                                 |
| \$00001000<br>\$00001004<br>\$0000100A                             | MOVE.W<br>JSR<br>RESET      | #\$0008,D0<br>\$00001030          |
| \$0000100C<br>\$00001010                                           | STOP<br>JMP                 | #\$2500<br>\$00001000             |
| Subroutine<br>\$00001030<br>\$00001032<br>\$00001034<br>\$00001034 | NOP<br>SUBQ.W<br>BNE<br>RTS | #\$01,D0<br>\$FA(PC)              |
|                                                                    | (ea)                        | = Signed displaceme<br>= \$FFFFFF |
|                                                                    |                             |                                   |

FIGURE 3.17 Main program and subroutine (for Example 3.6).

Comment ;Move data word #\$0008 into DO ;Jump to subroutine at \$00001030 Generate reset pulse ;load \$2500 into SR and Stop ;Jump to \$00001000 (start) ;No operation ;Subtract 1 from DO (decrement DO) ; If not zero, branch to (ea)\*\*\* ;return from subroutine nent + advanced PC FFA + \$00001036 = \$00001030

In the software of Figure 3.17, we used absolute numbers and hex values to specify displacements and the jump and branch operations. This enabled us to show the details of the program flow at the machine level. This approach can become tedious and inefficient, however, especially if the software contains many loops and conditions. Assembly language programming, in which numbers are represented by symbols, is a better alternative in developing the software. We will learn more about these programming techniques in the following chapter.

In addition to the instruction groups discussed, the 68000 has a special group of instructions to support multiple register transfers, linking and unlinking of the stack, multiple decision schemes and software interrupts (traps). These complex instructions will be discussed in later chapters, after assembly programming concepts are introduced. The instruction execution time is another important parameter. It specifies the actual time of execution of an instruction including calculation of the <ea> and obtaining the operands. We will now present these concepts.

## 3.5 INSTRUCTION TIMING CONSIDERATIONS

The 68000 is activated by a clock signal (4- to 12-MHz range). **Instruction time** refers to the time required to execute an instruction without any wait states. The fundamental unit of time is the processor clock cycle time (T). When the 68000 reads the op.word from the program memory, or reads the operands from memory or I/O, it is referred to as the **read bus** cycle. Similarly, when the processor writes the operands into the memory or I/O, it is referred to as the write bus cycle. The bus cycle in general may be a read or a write bus cycle.

#### Read/Write Timing

A typical bus cycle takes four clock cycles (or four T-states). The op.word fetch is always a read operation and takes one read bus cycle. Depending upon the instruction, the processor may perform further read operations (to obtain operands) and write operations (to write operands). In case of the 68000 and 68010/12 processors, each bus cycle involves a 16-bit data transfer. In case of the 68008, each bus cycle involves an 8-bit data transfer (due to an 8-bit data bus). The instruction timing is specified in terms of the total number of T-states and the associated read/write bus cycles.

#### Instruction Timing Computation

Consider the T(R/W) values shown in Figure 3.18 for the 68000. In case of the MOVE.W D1,D2 instruction, only the op.word needs to be fetched from the external memory, which involves one read operation. The source and the destination operands are within the processor; hence, the instruction does not need any further read or write bus cycles. Thus, the T(R/W) values are 4(1/0). In case of the MOVE.L (A1),(A2) in-

| Instruction                      | T(R/W)            | Con                   |
|----------------------------------|-------------------|-----------------------|
| MOVE.W D1,D2<br>MOVE.L (A1),(A2) | 4(1/0)<br>20(3/2) | ;Mc<br>;Mc<br>by      |
| MOVE.B -(A3),DL                  | 10(2/0)           | A)<br>MC;<br>PI<br>PI |

#### FIGURE 3.18 T(R/W) values and instruction timing for the 68000.

struction, the processor has to perform the op.word fetch and two more read operations of the memory to obtain the long-word source operand at the location addressed by the contents of Al. In addition, the processor has to perform two write operations to write the long word at the destination location addressed by the contents of A2. Thus, there are three read and two write bus cycles, corresponding to 20 T-states. The T(R/W) values are 20(3/2).

In case of the MOVE.B -(A3),D6 instruction, the processor has to perform the op.word fetch and one more read operation of the memory to obtain the byte operand from the source  $\langle ea \rangle$ . The source  $\langle ea \rangle$  is the predecremented A3 and involves address computation. The 68000 usually takes two additional T-states to perform the <ea> computation. There is no memory write cycle involved, since the destination operand D6 is within the processor. Thus, the T(R/W) values, including the computation time for the  $\langle ea \rangle$ , are 10(2/0). If the computation time overlaps some other processor activity in the instruction, the additional T-states are not required. (See Appendices B and D for the T(R/W) values for 68000 instructions.)

We will now present an example problem to review instruction timing.

#### Example 3.7 Instruction timing.

The software of Figure 3.17 is repeated with the T(R/W) values indicated in Figure 3.19.

- 1. Explain the T(R/W) values for the JSR, RESET, BNE, and RTS instructions. (Obtain information from Appendices B and D.)
- 2. If the 68000 is operating at an 8-MHz clock, compute the execution time for the delay subroutine.

#### Solution

erations to obtain the address operand \$00001030. It stores the PC in the main routine on the stack, which takes two write operations, before going to the subroutine. Thus, the T(R/W) values involve three read and two write bus cycles and 20 T-states. The T(R/W) values = 20(3/2).

mment ove word in DL into D2 love long word from memory addressed y (A1) into memory addressed by (5A ove byte from memory addressed by redecremented (A3) into D6

1. JSR \$00001030: The processor fetches the op.word and performs two more read op-

**RESET:** The processor needs to fetch only the op.word, involving only one read bus cycle. However, the reset pulse is held active for 128 T-states, resulting in T(R/W) values = 132(1/0).

BNE FA(PC): The processor fetches the op.word, computes the <ea>, and fetches the new op.word at the branched location, if the branch is taken. This involves two read bus cycles and address computation, resulting in T(R/W) values = 10(2/0). If the branch is not taken, the computed <ea> has to be recomputed to the original value. Thus, only one op.word fetch and two computations are involved, resulting in T(R/W) values = 8(1/0).

RTS: The processor fetches the op.word, performs two more read operations to obtain the stored PC from the stack, and fetches the new op.word from the new PC location. This involves four read bus cycles, resulting in T(R/W) values = 16(4/0).

2. Execution time: The delay timing loop between the NOP and the BNE instruction runs seven times (refer to Example 3.6) until DO is decremented to 0. The loop exists the eighth time. The computation of the execution time is as follows:

At an 8 MHz clock, each T-state =

The 68008 timing computation is similar, except that the read and write bus cycles transfer a byte of data instead of a word as in the 68000. This makes the 68008 instruction fetch and execution times (for word and long-word operands) twice as long as in the case of the 68000.

## 3.6 SUMMARY

In this chapter we examined the instruction set of the 68000. It has 56 generic instructions, some of which have several variations. These instructions follow a consistent structure. The same mnemonic representing an instruction can be used with appropriate attributes and extensions to refer to different operand sizes and addressing modes.

| L | Main program<br>PC<br>\$00001000<br>\$00001004<br>\$00001004<br>\$00001004<br>\$00001004 | Instruction<br>MOVE.W<br>JSR<br>RESET<br>STOP<br>JMP | <i>Instruction</i><br>MOVE.W #\$COOG.DC<br>JSR \$COOO1.030<br>RESET<br>STOP #\$2500<br>JMP \$COO1.000 | Comment<br>Nove data word #\$0008 into D0<br>Jump to subroutine at \$00001030<br>Generate reset pulse<br>Load \$2500 into SR and Stop<br>Jump to \$00001000 (start) | T(R/W)                                             |
|---|------------------------------------------------------------------------------------------|------------------------------------------------------|-------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|
|   | Subroutine<br>\$00001032<br>\$00001032<br>\$00001034<br>\$00001034<br>\$00001034         | NOP<br>SUBQ.W<br>RTS                                 | NOP<br>SUBQ.W #\$U1,DU<br>BNE \$FA(PC)<br>RTS                                                         | No operation<br>Subtract 1 from DU(decrement DU)<br>If not zero, branch to (ea)*<br>return from subroutine<br>*T(R/W) branch taken = 10(2/0)<br>not taken = 8(1/0)  | 4 ( 1/0 )<br>4 ( 1/0 )<br>10 ( 2/0 )<br>16 ( 4/0 ) |
| / | FIGURE 3.19 In<br>3.7).                                                                  | struction-tin                                        | ne and execution                                                                                      | FIGURE 3.19 Instruction-time and execution-time computation for the 68000 (Example 3.7).                                                                            |                                                    |

| # T-states per loop (between NOP and BNE) = 18            |                 |       |  |  |
|-----------------------------------------------------------|-----------------|-------|--|--|
| # T-states per seven loops                                | $= 7 \times 18$ | = 126 |  |  |
| # T-states for the eighth and the la                      | ast loop        | = 32  |  |  |
| (BNE has only eight T-states an                           | d RTS has       |       |  |  |
| to be included)                                           |                 |       |  |  |
| Total # T-states in the delay su                          | broutine        | = 176 |  |  |
| Hz clock, each T-state = $1/8$ MHz = $0.125$ microsecond. |                 |       |  |  |
| Delay routine execution time = # T-states × time/state    |                 |       |  |  |

 $= 176 \times 0.125$ = 22 microseconds

Some of the instructions for the 68000 are of the single-operand type. In such cases, the specified operand is the destination operand on which the given operation is performed. Other instructions are of the double-operand type in which the first operand is the source operand and the second is the destination operand. The final result is put in the destination.

The 68000 instruction set is subdivided into several groups: data movement, binary and BCD arithmetic, logical and bit-manipulation, program and system control, and special category.

Data movement instructions deal with the physical movement of the data operands. The binary arithmetic instructions deal with the binary arithmetic and data processing. The BCD instructions deal with decimal numbers. The binary operations are faster than the BCD operations. In the multiprecision arithmetic type of operations, the extend (X) flag bit is used to carry the result from the previous operation to the current operation.

The logical instructions deal with logical data manipulation and assist data processing operations. The bit-manipulation instructions deal with bit-level data manipulations, which are very useful in I/O applications in which a single bit must be tested or changed.

The program control instructions deal with conditional and unconditional control of the program flow. These instructions are particularly useful in controlling loops, calling subroutines, branching to specified locations on condition, and branching or jumping to specified locations unconditionally. For conditional transfers, the instruction checks the corresponding flag bits and makes the decision for a transfer.

The system control instructions deal with system functions, such as stopping the processor, resetting the peripherals, and so forth. These instructions are used at the operating system level to control and synchronize system operation. In order to enhance efficiency of the operating system activity, certain instructions dealing with the status register and the stack pointers are classified as privileged instructions. These should only be used in the supervisor mode. To do otherwise results in an error condition causing the processor to go into the supervisor mode.

Instruction timing is a very important parameter. The read or the write bus cycle takes four clock cycles (T-states) without any wait states. The op.word fetch is always a read bus cycle. An instruction may consist of several read and write bus cycles. The execution time of a program is the compounded execution time of the instructions and the program loops.

Assembly language programming, which will be covered in the next chapter, is a better way to develop software than using absolute numbers and hex values.

## PROBLEMS

Note: All the problems in this section can be reworked using the 68008 processor to compare its performance with that of the 68000.

- (a) MOVEA.L A1.A3 (b) MOVE.W (A1),D0 (c) MOVE.B -(D2),D3
- (a) MOVE.L #\$1234098A,D6 (b) EXG A2.D4 (c) SWAP D3
- (a) move byte in DO into memory addressed by A2; (b) move byte in memory addressed by A2 into D3; (c) move long word in memory addressed by A3 into D3; (d) move long word in D3 into memory addressed by A2.
- efficient? Why of why not?
- efficient? Why or why not?
- SUB instructions? Give the reason.

(a) ADDQ.L #\$0F,D4 (b) SUBILL #\$0034567C,A7 (c) ADDX.B -(A3),-(A1)(d) SUB.B 0A(PC),D2

- (a) ADDX.L -(A2).-(A3) (b) ADD.L\$123C(A1.D1.W).D0
- (a) immediate addressing mode; (b) quick addressing mode;
  - (c) d(PC,Rn); (d) An.
- (a) SUB.W \$1235.DO (b) MOVE.W #\$2400,SR
- operations using the initial values of Figure 3.6: (a) MOVE.L (A1),(A0)+ (b) ADDO.W #\$07,D0 (c) ADD.W - (A1), -(A1)(d) SUB.W (A1)+,(A1)+

3.1 Which of the following instructions are valid and which are not valid? Give the reason.

3.2 How many words are each of the following instructions? Give the reason.

3.3 Write mnemonic instructions for the following:

3.4 Consolidate (a) and (b) of Problem 3.3 into one instruction, if possible. Is this more

3.5 Consolidate (c) and (d) of Problem 3.3 into one instruction, if possible. Is this more

3.6 Which of the following forms are allowed and which are not allowed for the ADD and

3.7 How many words are each of the following instructions? Give the reason

3.8 Using the information from Figure 3.4, classify each of the following addressing modes:

3.9 Which of the following instructions is likely to generate an error? Why?

3.10 Indicate the results of the affected registers and memory after each of the following

3.11 Repeat Problem 3.10 on condition that the instructions are used in sequence.

3.12 The following program is run in sequence:

#### ADDX.W D0,D1 SWAP D1 EXT.L DO ADDX.L D1,D0

Using the initial values of Figure 3.6, indicate the contents of the affected registers at each step of the sequence.

3.13 What are the contents of the affected registers and memory after each of the following operations? Use the initial values of Figure 3.6.

(a) CMP.L D0,D1 (b) CMPA.W A0,A1 (c) TST.L -(A1)

3.14 In the following program, use the initial values of Figure 3.6:

#### NEG.W D2 MOVEA.W D2,A2 CMPA.W A2,A1

What are the values of the affected registers, including the status register?

3.15 What are the results of the following operations? Use the initial conditions of Figure 3.6. Show the contents of the affected registers and the memory locations.

(a) MULU D2,D1 (b) MULS D1,D2

(c) DIVU D2,D1 (d) DIVS D1,D2

3.16 Write a sequence of instructions to add long words addressed by (A1) and (A2), with the result in a location addressed by (A3). Use any addressing modes.

- 3.17 Write a sequence of instructions to compute the average of word operands contained in the D0-D5 registers. (Hint: you may want to sign extend to long words before the actual addition!)
- 3.18 In a control system application as shown in the following diagram, 16-bit X and Y words are entering the 68000-based system. Registers A0 and A1 point to X and Y words. X is larger than Y and is a positive number. It is required to compute a control word Z, given by

 $Z = 0.25([X - Y]^2)$ 

and output to a location addressed by A2. Write the sequence of instructions as a subroutine.



| 3.19 | Using the initial values of Figure 3.6, com<br>indicate the contents of the affected register                                                                     |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | <ul> <li>(a) AND.B D2,D1</li> <li>(b) AND.L D1,D0</li> <li>(c) EOR.W #\$AA55,D1</li> <li>(d) NOT.L (A1)</li> </ul>                                                |
| 3.20 | Repeat Problem 3.19 on condition that the                                                                                                                         |
|      | Compute the results of the following opera<br>assuming the operations are executed one                                                                            |
|      | <ul> <li>(a) ROL.W D2,D0</li> <li>(b) ROR.L #\$4,D0</li> <li>(c) ASL.W #\$2,D2</li> <li>(d) LSL.L D2,D1</li> </ul>                                                |
| 3.22 | Repeat Problem 3.21 on condition that the                                                                                                                         |
| 3.23 | Compute the results of the following opera<br>assuming the operations are executed in se                                                                          |
|      | <ul> <li>(a) BCHG.L #\$1E,D0</li> <li>(b) BTST.B #\$3,(A1)</li> <li>(c) BCLR.L D2,D1</li> <li>(d) BSET.B #\$4,-(A1)</li> </ul>                                    |
| 3.24 | Write a series of instructions to invert the between \$0034FE74 and \$0034FE7C. (Hin                                                                              |
| 3.25 | Compute the effective address in each of the at the branch instruction is \$00001040. In for the branch to occur.                                                 |
|      | (a) \$00001040       BEQ \$4A(PC)         (b) \$00001040       BNE \$FA(PC)         (c) \$00001040       BLE \$FF00(PC)         (d) \$00001040       BGT \$08(PC) |
| 3.26 | Write a program to clear the memory word \$00002080.                                                                                                              |
| 3.27 | There are 128 word X and Y binary strings<br>strings (the least significant words in each                                                                         |
|      | X word<br>Word 127                                                                                                                                                |
|      |                                                                                                                                                                   |

:  $(A0) \rightarrow Word 0$ 

Write a subroutine to add these strings and store the result in memory addressed by A2. 3.28 Repeat Problem 3.27, performing subtraction instead of addition. 3.29 Repeat Problem 3.27 with BCD data. 3.30 Repeat Problem 3.28 with BCD data.

mpute the results of the following operations and ers:

e instructions are executed in sequence. ations using the initial values of Figure 3.6 and at a time.

e instructions are executed in sequence. rations using the initial values of Figure 3.6 and equence:

long-word contents of memory contained nt: you may want to use conditional branches.) the branch operations listed below. The PC value each case, specify the condition to be satisfied

ds between the locations \$00002000 and

gs in memory. A0 and A1 point to the end of the case), as shown:

•••

3.31 Show the T(R/W) values for each of the instructions in the following software subroutine:

| PC<br>\$00002000<br>02<br>04<br>06<br>08<br>08 | CMPI.L     | DO<br>(A1)<br>DO,(A1)<br>#\$02,DO<br>#\$00000400,DO |
|------------------------------------------------|------------|-----------------------------------------------------|
| ŌE                                             | BNE        | \$F4(PC)                                            |
| 1,0<br>1,2                                     | NOP<br>RTS |                                                     |

- 3.32 Analyze the software of Problem 3.31. What is being accomplished? How many times is the loop executed before the return instruction?
  - Indicate the contents of D0 and memory addressed by A1 when the program returns to the calling program.
- 3.33 The 68000 processor operates on an 8-MHz clock. Compute the time of execution of the software in Problem 3.31.
- 3.34 The 68000 processor operates on an 8-MHz clock. Write a subroutine that will provide a 0.1-second delay time.

## ENDNOTES

- 1. Triebel, W., and Singh, A. 16-Bit Microprocessors: Architecture, Software and Interfacing Techniques. Englewood Cliffs, NJ: Prentice-Hall, 1985.
- 2. Motorola, Inc. M68000 16/32-Bit Microprocessor Programmer's Reference Manual, Fifth Edition. Englewood Cliffs, NJ: Prentice-Hall, 1987.
- 3. Harman, T., and Lawson, B. The Motorola MC68000 Microprocessor. Englewood Cliffs, NJ: Prentice-Hall, 1985.
- 4. Motorola, Inc. MTT8: 68000 Course Notes. Phoenix, AZ: Motorola Technical Operations, 1987.
- 5. Triebel, W., and Singh, A. 16-Bit Microprocessors: Architecture, Software and Interfacing Techniques. Englewood Cliffs, NJ: Prentice-Hall, 1985.
- 6. Tocci, R., and Laskowski, L. Microprocessors and Microcomputers. Englewood Cliffs, NJ: Prentice-Hall, 1979.
- 7. Harman, T., and Lawson, B. The Motorola MC68000 Microprocessor. Englewood Cliffs, NJ: Prentice-Hall, 1985.
- 8. Motorola, Inc. MC68000, MC68008, MC68010/12 Data Books. Phoenix, AZ: Motorola Technical Operations, 1983.
- 9. Stranes, T. "Design Philosophy Behind the M68000." Byte (Apr., May, Jun. 1983).
- 10. Stranes, T. "Design Philosophy Behind the M68000." Byte (Apr., May, Jun. 1983).
- 11. Motorola, Inc. MTT8: 68000 Course Notes. Phoenix, AZ: Motorola Technical Operations,

#### 1987.

# 68000 Software Considerations and **Assembly Programming Applications**

#### Objectives

In this chapter we will study:

Assembly-level programming techniques for the 68000 Concepts of software design and implementation Practical program development and applications Concepts of macros and programs with macros Special instruction groups and applications

# **CHAPTER**

## 4.0 INTRODUCTION

The required software for the 68000 microprocessor can be easily developed using assemblers and cross assemblers. **Assembly language programs** use the instruction mnemonics of the processor. **Assemblers** and **cross assemblers** are software utilities that convert assembly language programs into the appropriate form of machine code, consisting of binary Is and 0s. Programs written in assembly language are usually more efficient with respect to code content and execution time than programs written in such higher level languages as BASIC, FORTRAN, PASCAL, and C; however, the higher level languages do provide programming ease. Industrial and I/O application programs are often written in assembly language. Assembly language programming requires a complete understanding of processor architecture, addressing modes, and the instruction set.<sup>1</sup>

**Software** usually refers to programming techniques that take into consideration system hardware resources and optimization of code content and execution time. **Programming** refers to code development to accomplish a given task. The terms *software* and *programming* are used interchangeably in most industrial circles; however, for purposes of this text, we will maintain the distinction between these terms.

Study of assembly language techniques and software considerations will provide the knowledge and background necessary to develop assembly language programs and software on 68000-based systems.

Most of the programs in this chapter are suitable for any 68000-based hardware; thus, our discussions are independent of specific hardware.

#### 4.1 ASSEMBLY LANGUAGE SOFTWARE AND PROGRAMMING TECHNIQUES

It is impractical and tedious to use actual addresses and instruction codes in developing assembly programs. Symbols and labels can be used in place of the actual addresses if assembler utilities are available.<sup>2</sup>

#### Assembler, Cross Assembler, Linker, and Loader Utilities

Figure 4.1 illustrates a software system configuration using a host computer, an emulator, and a 68000-based target system. The software development is done on the **host system** and the code is downloaded to the **target system** for the actual operation.

In Figure 4.2 the various steps involved in the software development process are indicated. The assembly-level program is developed with the help of an editor or word-processor utility, and is known as the **source program**. The **source program file** usually has an extension (.src); for example, TEST.SRC is the source file in Figure 4.2. After correcting any typing errors, the source program is run through the assembler or the cross-assembler utility.

FIGURE 4.1 Typical system configuration for software development.



Assemblers and Cross Assemblers These are the software utilities that convert a program in assembly language into the corresponding machine code. The machine-code program is also known as the **object code**. The corresponding file is TEST.OBJ. If the host computer has the same processor as the target system, the assembler utility is used. On the other hand, if the computer has a processor different from that of the target system, the cross-assembler utilities are similar to each other in function. They also generate a **list file** (TEST.LST) contain-



ing the machine code, the instruction mnemonics, symbols, labels, and the translated addresses and numbers. This file is very useful in debugging the programs.<sup>3</sup>

*Linkers and Loaders* The linker utility provides absolute addresses for the machine-code programs in the real operating memory environment of the target system. It also links several machine-code programs, if necessary, and provides an **absolute file** (TEST.ABS).

The loader utility provides the required format for the absolute file to be downloaded into the target system. For the 68000 family of processors, this is usually the Motorola-S format. Another common format is the INTEL-Hex format.

#### Writing Assembly Programs and Software Development

Most currently available assembler and cross-assembler utilities are of the two-pass type. In the first pass, symbols and labels in the assembly source program are converted into the corresponding numbers and displacement values. In the second pass, these numbers or values are substituted for the existing symbols and labels, and the machine-code file is generated. Present-day assembler and cross-assembler utilities are able to identify syntax, instruction, and operand errors at the time of assembly and display them. These errors then can be corrected and the assembly process repeated.

In developing the source program, **assembler directives** can be used. These directives are a set of commands associated with the assemblers and cross assemblers. We will introduce those directives typical of most assemblers or cross assemblers. For information on additional directives, appropriate manuals may be consulted.<sup>4</sup>

Figure 4.3 illustrates the assembly source program (TEST.SRC). In Figure 4.4 the assembled program listing (TEST.LST) is presented. In the discussion numbers in square brackets [] refer to the bracketed numbers in the figures, which correspond to important assembler directives or events.

[1] Comment directive: Usually a delimiter such as a semicolon (;) is used as an assembler comment directive to introduce the comments. The comments are provided to explain the program flow. The assembler will not generate any machine code for a comment, but will include the comment statements in the list file.

example: ;test.src &\&\&? (at line 1)

The preceding comment statement is listed in the assembled program listing, but it is not assembled to machine code.

[2] LLEN and OPT directives: These are the line length and the option directives, which specify the printer line length and any specific options. In our example, the line length is set at 108 columns. Option A generates an absolute file after the linker operation.

[3] ORG directive: This is the origin directive. It specifies the starting address of the assembled program.

| ;1                                    | this is a source program to show      |          |
|---------------------------------------|---------------------------------------|----------|
|                                       | the format of a typical assembly      |          |
|                                       | language program.                     |          |
| ;                                     |                                       |          |
| ;test.src &\&\                        | \87                                   | ;[1]     |
|                                       | of length, option                     | 1        |
| ;and origin                           |                                       | . [4]    |
|                                       | 108                                   | ;[2]     |
| OPT                                   |                                       | 131      |
| ORG                                   |                                       | ;[3]     |
|                                       | of symbols and values                 |          |
| VALUEL EQU                            |                                       | ;[4]     |
| VALUES EQU                            |                                       |          |
| PORT EQU                              | \$ADQQ                                |          |
| ;move valuel                          | into DO and jump to                   |          |
| ;delay subrou                         | N WALKEL DO                           | ;[5]     |
|                                       | .W #VALUE1,DO<br>DELAY                | [6]      |
|                                       | age to port until \$                  | , ( 0, 1 |
| , output messe<br>Character an        | nd back to start                      |          |
|                                       | A.L #MSGE, AO                         |          |
|                                       | B (AO)+, DL                           |          |
|                                       | .B #'\$',D1                           |          |
| BEQ                                   | START                                 |          |
|                                       | .B D1, PORT                           |          |
| JMP                                   | DSPLY                                 |          |
| ;delay subrou                         | utine. Loops until DO                 |          |
| ; is decrement                        | ted to U.                             |          |
| DELAY NOP                             | מר ⊂יתווזגט⊭                          |          |
| BNE                                   | .W #VALUE2,DO<br>DELAY                |          |
| RTS                                   | F LEID &                              |          |
| ;message to h                         | be output                             |          |
| ; ; ; ; ; ; ; ; ; ; ; ; ; ; ; ; ; ; ; | •                                     |          |
| MSGE DC                               | 'ABCDE\$'                             | ;[7]     |
| DBUF DS                               | 128                                   | ;[8]     |
| END                                   |                                       | ;[9]     |
|                                       | · · · · · · · · · · · · · · · · · · · |          |

FIGURE 4.3 Assembly language source program (TEST.SRC) for 68000-based systems.

example: ORG \$1000 (at line 6)

The first instruction of the assembled program will start at PC location \$1000, as can be seen from the assembled listing.

[4] EQU directive and symbols: This is the equate directive. It provides constant or computed values to the symbols.

example: VALUE1 EQU \$0008 (at line 8)

| ;this is a source program to show<br>;the format of a typical assembly<br>;language program.<br>;                                                                                                                                                                                         |              |  |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--|--|--|--|
| LINE ADDR                                                                                                                                                                                                                                                                                 |              |  |  |  |  |
| 1 ;test.src 8\8\87<br>2 ;declaration of length, option<br>3 ;and origin<br>4 LLEN 108                                                                                                                                                                                                     | ;[1]         |  |  |  |  |
| 5 OPT A<br>6 ORG \$1000<br>7 ;declaration of symbols and values                                                                                                                                                                                                                           | ;[2]<br>;[3] |  |  |  |  |
| 8 0000000A       VALUEL EQU       \$0006         9 0000001       VALUE2 EQU       \$0001         10 0000A000       PORT EQU       \$A000         11       :move value1 into D0 and jump to                                                                                                | ;[4]         |  |  |  |  |
| 12;delay subroutine13 00001000 303C 0008 STARTMOVE.W #VALUE1,D014 00001004 611A 4E71BSR15;output message to port until \$                                                                                                                                                                 | ;[5]<br>;[6] |  |  |  |  |
| 15       ;character and back to start         16       ;character and back to start         17 00001008 207C 0000 1028       MOVEA.L #MSGE,A0         18 0000100E 1218       DSPLY MOVE.B (A0)+,D1         19 00001010 0C01 0024       CMPI.B #'\$',D1         20 00001014 67EA       BEO |              |  |  |  |  |
| 21 00001016 13C1 0000 AGOO       MOVE.B D1,PORT         22 0000101C 4EF8 100E       JMP         23       ;delay subroutine. Loops until D0                                                                                                                                                |              |  |  |  |  |
| 24       ;is decremented to 0.         25 00001020 4E71       DELAY NOP         26 00001022 5340       SUBQ.W #VALUE2,DO         27 00001024 66FA       BNE DELAY         28 00001026 4E75       RTS         29       ;message to be output         30       ;                            |              |  |  |  |  |
| 31 00001028 4142 4344 MSGE DC 'ABCDE\$'<br>31 0000102C 4520 2D2D<br>31 00001030 2400                                                                                                                                                                                                      | ;[7]         |  |  |  |  |
| 32 00001032 DBUF DS 128<br>33 00001132 END                                                                                                                                                                                                                                                | ;[8]<br>;[9] |  |  |  |  |
| ASSEMBLER ERRORS = 0                                                                                                                                                                                                                                                                      |              |  |  |  |  |
| SYMBOL TABLE                                                                                                                                                                                                                                                                              | 1            |  |  |  |  |
| DBUF 00001032 DELAY 00001020 DSPLY 00001008<br>MSGE 00001028 NARG 00000000 PORT 00004000<br>START 00001000 VALUE1 00000008 VALUE2 0000001                                                                                                                                                 |              |  |  |  |  |

FIGURE 4.4 Assembled program listing (TEST.LST) corresponding to the source program in Figure 4.3.

VALUE1 is a symbol for which the numerical value is \$0008. The assembler replaces the symbol VALUE1 with \$0008 in the assembly process by means of the. EQU directive. The other symbols are VALUE2 and PORT, the numerical values of which are \$0001 and \$A000, respectively.

[5] Label: This is a symbolic representation of the address of a program statement. Other program statements can refer to this label as the source program is being written. The assembler configures the appropriate numerical value for the label.

example: START MOVE.W #VALUE1,DO

START is a label, referring to the program location of \$00001000, as shown in the assembled listing.

Assembly listing (Figure 4.4): The actual program starts at line 13 and reads:

13 00001000 303C 0008

The interpretation of the preceding line is as follows:

13 = Line number generated by the assembler for listing convenience. 00001000 => Hex address of the first instruction, according to the earlier ORG statement.  $303C\ 0008 => Op.code\ (303C)$  and the operand (0008) for the MOVE.W #VALUE1,D0 instruction. The assembler has substituted 0008 for the symbol VALUE1.

[6] Branch operations: In branch operations, the assembler configures the required displacement to branch to the location specified by the label.

example: BSR DELAY (at line 14)

The op.code is 611A for the preceding instruction, which contains the displacement (1A) to branch to the location \$00001020. This location corresponds to the label DELAY.

[7] DC directive: This is the define constant directive. It is used to define the byte (DC.B), the word (DC.W), the long-word (DC.L), or the ASCII character constants. The ASCII characters are enclosed in single quotation marks (").

example: MSGE DC 'ABCDE --\$1 (at line 31)

Sequential locations starting at \$00001028 are filled with the ASCII values: \$41 for A, \$42 for B, and so on. MSGE is a label corresponding to the address \$00001028.

(at line 13)

START MOVE.W #VALUE1,DO

[8] DS directive: This is the define storage directive. It is used to define storage space in memory. It can be specified as bytes (DS.B or DB), words (DS.W or DS), or long words (DS.L).

example: DBUF DS 128 (at line 32)

Storage space of 128 words (256 bytes) is defined as DBUF, starting at location \$00001032.

[9] END directive: This directive signifies the end of the assembly process. Statements beyond the END directive are not recognized by the assembler.

**Other Delimiters and Directives** To distinguish among operand types, certain **delimiters** are used. These delimiters depend on the assembler or the cross assembler. Some of the standard ones are as follows:

- = hex data or operand
- # = > immediate data or operand
- ; = comment beginning

**Symbol Table** Assemblers and cross assemblers also generate a symbol table as shown below the program listing in Figure 4.4. It provides a quick reference for the symbols and labels used in the program.

The following example problem provides a review of the assembly process of 68000 programs.

Example 4.1 Assembler usage for the 68000.

Refer to the source, assembled, and listed programs of Figures 4.3 and 4.4.

1. Are the statements

PORT DSPLY

symbols or labels? Why? What are their hex values?

2. Where does the program branch after executing the instruction

BEQ START (at line 20)

What is the offset value calculated by the assembler? How is the effective address value computed?

3. What are the contents of the A0 register after executing the instruction

MOVEA.L #MSGE, AO (at line 17)

What are the details of the op.code and the operands?

#### Solution

1. Symbols and labels: PORT is a symbol, since it is declared by the EQU directive. It has a hex value \$A000.

DSPLY is a label, since it is introduced in the program to identify the corresponding program location. It has a hex value of 0000100E.

2. BEQ START: If the branch condition is satisfied, the program branches to location \$00001000, which corresponds to the label START. The offset or the displacement calculated by the assembler is EA, which is a part of the op.code 67EA.

#### Offset = \$EA

**Effective address calculation:** 

PC value after reading the op.code = \$00001016

|                                | +                     |
|--------------------------------|-----------------------|
| Sign-extended displacement EA  | => <u>\$FFFFFFFEA</u> |
| (in twos-complement form)      |                       |
| Effective address for branch   | => \$00001000         |
| (corresponding to label START) |                       |

3. Contents of A0 after the MOVEA.L #MSGE,A0 instruction: MSGE is a label and #MSGE corresponds to the address location \$00001028. As such, A0 is loaded with the value \$00001028.

#### A0 = \$00001028

**Op.code and operand details:** Line 17 shows

00001008 207C 0000 1028 MOVEA.L #MSGE,A0

where

00001008=> Program location of the instruction207C=> Op.code of the instruction00001028=> Operand value moved into A0

Since the preceding example was used primarily to review the assembly process, we did not focus on analyzing the program. This analysis would prove useful to the reader to enhance understanding of software development.

#### Programming and Software Engineering Considerations

From a programmer's point of view, the program in Figure 4.4 is a 33-line program, including comments and declarations. Programmers may not be concerned about memory appropriations and code content. On the other hand, software engineers would make sure that appropriate memory was allocated for the buffer. For example, they would examine lines 32 and 33 of the listed program to ensure that the 128 words of memory space was allocated. This may be done in the following way:

| Ending address of the DBUF (line 33)                                      | => | \$00001132               |
|---------------------------------------------------------------------------|----|--------------------------|
|                                                                           | -  |                          |
| Beginning address of the DBUF (at line 32)<br>Size of the buffer in bytes |    | \$00001032<br>\$00000100 |
| 0100  bytes = 256  bytes = 128  words                                     |    |                          |

which is the requested memory space for the buffer.

Similarly, software engineers also would be concerned about whether the entire program was on the even boundaries and whether the entire code content was correct. Although there are some traditional distinctions between programmers and software engineers, these distinctions are rapidly vanishing as technologies continue to advance.

## 4.2 DATA MOVEMENT, DATA-COMPARISON SOFTWARE, AND APPLICATIONS

The majority of operations in any computer system deal with data movement between two or more locations. For example, in a file-management system, data from one section of memory may be moved into another section. Data rearrangement involves extensive data-comparison procedures, which we will now examine.

#### Block Transfer Applications and Software Considerations

The basis for any data movement operation is the **block transfer.** It usually involves two pointers: the first refers to the starting address of the source block and the second to the starting address of the destination block. In addition, there is a **loop counter**, which keeps track of the number of data elements being transferred.

Figure 4.5 shows a typical block movement sequence written as a subroutine. DO is chosen as the loop counter and is initialized to \$100 at line 10. Al is the source pointer and A2 is the destination pointer. They are initialized to \$00004000 and \$00006000 at lines 11 and 12. The program loop between lines 16 and 18 transfers successive long words from the source block to destination block, until DO is decremented to zero. In this case, the number of long words transferred are \$100 or 256. At the end of the successful block transfer, the software returns to the calling program by means of the RTS instruction at line 19.

|   | LINE ADDR                                                                                                   |
|---|-------------------------------------------------------------------------------------------------------------|
|   | ነ<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9                                                                   |
|   | 10 00001000 303C 0100 INI<br>11 00001004 227C 0000 4000<br>12 0000100A 247C 0000 6000<br>13<br>14           |
|   | 15<br>16 00001010 24D9 100<br>17 00001012 5340<br>18 00001014 66FA<br>19 00001016 4875<br>20<br>21 00001018 |
| ĺ | ASSEMBLER ERRORS $\Rightarrow$ O                                                                            |
|   | INIT 00001000 LOOP 000010                                                                                   |

FIGURE 4.5 Typical 68000-based block movement sequence.

In the example problem that follows, we will consider software and timing in the block movement sequence.

Example 4.2 Block movement sequence. Consider the sequence of Figure 4.5.

- 1. Specify the final values of the A1, A2, and D0 registers after the loop has been completed and the RTS instruction is being executed.
- 2. The system operates on an 8-MHz clock. Compute the loop execution time T(loop) to transfer \$100 long words.
- 3. Modify any of the required instructions to transfer \$0400 long words. What is the new execution time of the loop?

;block data move 8/8/87 OPT A ORG \$1000 ; initialize A1, A2 with source ;and destination addresses and ;DD with number of words to be :transferred IT MOVE.W #\$0100,D0 MOVEA.L #\$00004000,A1 MOVEA.L #\$00006000,A2 ;move data from (A1) to (A2) ;until DD is decremented to D OP MOVE.L (Al)+,(A2)+ SUBQ.W #\$01,D0 BNE LOOP RTS ;returns to the calling program. END SYMBOL TABLE

010 NARG 0000000

#### Solution

1. Final values: The data movement loop between lines 16 and 18 is run \$100 times (until D0 is decremented to \$0000). Each time the loop is executed, A1 and A2 are postincremented by four (because of the long-word data transfers). At the end of the loop, A1 and A2 are incremented by \$0400 from their initial values.

The final values are

| D | 0 | = | \$00000000 |
|---|---|---|------------|
| A | 1 | = | \$00004400 |
| Α | 2 | = | \$00006400 |

2. Loop execution time: Using the T(R/W) values (refer to Chapter 3) for lines 16 through 18, we obtain

| 16 LOOP MOVE.L (A1)+,(A2)+ 20(3/2                                                                                |        |
|------------------------------------------------------------------------------------------------------------------|--------|
| 1?         SUBQ.W #\$01,D0         4(1/0           18         BNE         LOOP         10(2/0           (brance) | )<br>) |

The total number of T-states is 34, as indicated. This loop is run 256 (\$100) times. The clock period at an 8-MHz clock is 0.125 microsecond. Thus, the total loop execution time is as follows:

#### $T(loop) = 34 \times 256 \times 0.125 = 1088$ microseconds

**3. Modified software:** The loop counter D0 needs to be changed to \$0400 to transfer \$0400 or 1024 long words. Therefore, we modify the instruction at line 10 to

to accomplish the task.

Four times as many long words are transferred; hence, the loop time increases proportionately:

 $T(loop) = 4 \times 1088 = 4352$  microseconds

By appropriately initializing the pointer and the counter registers, it is possible to move any amount of data. However, care should be taken not to address unavailable memory locations or odd memory locations for word and long-word transfers.

## Data-Sequencing Applications and Software Considerations

In industrial and commercial applications, it is often required to arrange data either in ascending or descending order. This is accomplished by comparing the data elements and appropriately positioning them. The 68000 predecrement and postincrement addressing modes are particularly useful in such applications. Figure 4.6 illustrates data-sequencing software as a subroutine. We will now analyze and interpret the results.

| LINE ADDR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1         2         3         4         5         6         7         8         9         10         12         14         15         16       00001000         14         15         16       00001004         17       00001004         18       00001004         19       00001004         14       00001016         15       00001016         16       00001016         17       00001016         18       00001016         19       00001016         20       00001016         21       00001014         22       00001014         23       00001014         24       00001014         25       00001014         26       00001014         27       00001014         28       00001014 | <pre>SEQ.SRC 9/24/88<br/>;<br/>;sequences string of words<br/>;such that largest word is<br/>;in the lowest location.<br/>;AO and A1 point to the<br/>;beginning and end of the<br/>;string<br/>OPT A<br/>ORG \$LOOD<br/>;save original value of AO in AP<br/>MOVEA.L AO,A2<br/>;compare successive words. If the<br/>;second word is larger, branch to<br/>;EXCHG routine to swap them<br/>BGAGN MOVEA.L A2,AO<br/>NXTPR CMPM.W (AO)+, (AO)+<br/>BHI.S EXCHG<br/>ODOO 0002 SUBA.L #\$D2,AO<br/>CMPA.L A0,A1<br/>BNE.S NXTPR<br/>RTS<br/>;exchange the two words by swapping<br/>EXCHG MOVE.L -(AO),DO<br/>SWAP.W DO<br/>MOVE.L DD,(AD)<br/>BRA.S BGAGN<br/>END</pre> |
| ASSEMBLER ERRORS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | SYMBOL TABLE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| BGAGN 00001002<br>NXTPR 00001004                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | EXCHG 00001014 NARG 0000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

FIGURE 4.6 Data-sequencing and sorting software for a typical 68000-based system. (Courtesy of Motorola, Inc.)

AO contains the starting address of the string where the highest valued data element should be put. The next highest memory locations contain the sequentially decreasing values of the string. Al contains the ending address of the string. At line 12, the original value of the AO register is stored in A2 for later reference. At line 16, the stored value of AO is restored. At line 17, two successive words of the string are compared to each other. At line 18, the subroutine branches to the EXCHG routine if the second word is larger than the first. If the words are in proper order, the program proceeds.

At line 19, AO is decremented by two. This adjusts AO for comparison of the next two sequential locations. At line 20, AO is compared with Al to check whether it is the end of the string. If it is not the end of the string, the program branches back to line 17 (label NXTPR) to start the next comparison. If it is the end of the string, the program returns to the calling program by means of the RTS instruction at line 22.

The EXCHG software module is contained between lines 24 and 27. It obtains two sequential words as a long word into DO, swaps them, and puts them back in memory. This has the effect of exchanging the words. When this happens, the program branches back to the very beginning (line 16, labeled BGAGN). This will restart the data comparison process. When the routine returns to the calling program, the data string is completely adjusted so that the highest valued element is in the lowest memory location.

The following example problem considers software and timing in the datasequencing subroutine.

#### Example 4.3 Data-sequencing software.

For the software of Figure 4.6, the initial values of the A0 and A1 registers and the memory contents are as indicated in Figure 4.7.

FIGURE 4.7 Initial conditions (for Example 4.3).



- 1. Following the software of Figure 4.6, specify the data comparisons and rearrangement of data.
- 2. What are the final values of the A0 and A1 registers?
- 3. How many data comparisons must be made to obtain the final string? Is this number data dependent?

#### Solution

1. Data comparisons and memory contents: Figure 4.8 shows how the data comparisons are made and the final arrangement of the data string in memory. During the [1]st comparison, data elements 1234 and 5678 are compared and swapped. During

| Memory<br>Address                          | Memory<br>Contents                                   | Memory<br>Contents                                                                                                            | Memory<br>Contents                                                                               | Memory<br>Contents                                                                                                                                                |
|--------------------------------------------|------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| \$00004000<br>4002<br>4004<br>4006<br>4008 | 1 2 3 4<br>5 6 7 8 [1]<br>ABCD<br>0 E 7 1<br>4 3 2 1 | $   \begin{bmatrix}     2 \end{bmatrix} - 5678 \\     1 2 3 4 - [3] \\     ABCD \\     0 E71 \\     4 3 2 1   \end{bmatrix} $ | $   \begin{bmatrix}     4 \end{bmatrix} = 5678 \\     ABCD \\     1234 \\     0E71 \\     4321 $ | $   \begin{bmatrix}     5 \\     - ABCD \\     5 & 678 \\     5 & 678 \\     \hline     6 & 73 \\     -1 & 234 \\     0 & E71 \\     4 & 321 \\   \end{bmatrix} $ |
|                                            | (a) Initial contents                                 | (b) First<br>rearrangement                                                                                                    | (c) Second rearrangement                                                                         | (d) Final<br>rearrangement                                                                                                                                        |

FIGURE 4.8 Data comparisons and rearrangement of the data string (for Example 4.3).

the [2]nd comparison, the rearranged data elements (5678 and 1234) check in proper sequence and the program proceeds to the [3]rd comparison. During the [3]rd comparison, data elements 1234 and ABCD are compared and swapped. The program then restarts from the beginning. During the [4]th comparison, data elements 5678 and ABCD are compared and swapped. The program then restarts from the beginning. During the [5]th comparison, the rearranged data elements (ABCD and 5678) check in proper sequence and the program proceeds to the [6]th comparison. The final rearranged string results after the [7]th comparison, as shown in Figure 4.8(d). 2. Final values of A0 and A1: The process terminates when the contents of A0 are compared and found to be equal to those of A1 (= \$00004006).

A0 = \$00004006A1 = \$00004006

3. Number of data comparisons: As shown in Figure 4.8, seven data comparisons are made. These comparisons are data dependent.

#### #data comparisons = 7

There are some important software considerations in the preceding example. The number of comparisons, the number of times the loop gets executed, and the loop execution times are totally data dependent and do not have fixed values. When a fixed time of execution is required, this type of software should be avoided.

### 4.3 DATA PROCESSING APPLICATIONS AND SOFTWARE CONSIDERATIONS

Data processing involves extensive arithmetic operations on the data elements. The 68000 microprocessor has very powerful instructions to handle binary and BCD types of data.5



#### Multiprecision Addition and Subtraction Operations

Instructions employing the extended carry X (such as ADDX, SUBX) can be used to conduct multiprecision operations on binary data strings. For BCD operations, the X carry bit is always involved. In multiprecision operations, the least significant data elements are operated upon first (generating X carry). The next higher data elements are then operated upon, taking into consideration the previously generated X carry bit. The process continues until all data elements in the data string are operated upon.

Figure 4.9 illustrates a multiprecision binary addition program used in a data processing application. The source and the destination data strings are addressed by the Al and A2 registers, respectively. The Dl and D2 registers are used as working registers.

From line 12 to line 14, the X carry bit and the DI and D2 registers are cleared and initialized to zero. From line 17 to line 19, the two data strings addressed by Al and A2 are sequentially added, along with the X bit, using the predecrement addressing mode. A3 contains the ending address of the destination string.

| LINE ADDR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| i;add.src 9/25/88i;performs multiprecision additioni;on two binary strings in memory.i;Al-2 refers to the LSD of string1.i;A2-2 refers to the LSD of string2.i;Al-2 refers to the end of string2.i;Clear X bit, Dl and D2 registers.i;Clear X bit, Dl and string2.i;Start multiprecision addition;of string1 and string2.;Start multiprecision addition;get X bit into D2 and;put it along with string 2,;and return to the calling program.;ADX.W DL,D2iMOVE.W D2,-(A2)iMOVE.W D2,-(A2)iSYMBOL TABLE |
| AGAIN DDDD1408 NARG DDDDDDDD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

FIGURE 4.9 Multiprecision binary addition program for a 68000-based system.

When A2 is decremented below A3, the loop is terminated. At lines 23 and 24, the X bit is effectively moved into D2 and is put with the destination string. At line 26, the routine returns to the calling program. It should be observed that addition proceeds from a high memory address (where the least significant data elements are present) toward a low memory address (where the most significant data elements are present).

The following example problem addresses software concerns in multiprecision addition.

#### Example 4.4 Multiprecision addition.

The initial values of registers A1, A2, and A3 and the memory contents are indicated in Figure 4.10. Using the multiprecision addition software of Figure 4.9,

| Source Memory |               | Destination Memor | y                |
|---------------|---------------|-------------------|------------------|
| Address       | Contents(hex) | Address           | Contents(hex)    |
| \$00004000    | 1234          | \$00005000        | F878             |
| 4002          | 5678          | 5002              | C800             |
| 4004          | ABCD<=LSW     | 5004              | $A101 \leq =LSW$ |
|               | (source)      |                   | (destination     |
| 4006          | OE71          | 5006              | 0200             |

FIGURE 4.10 Initial conditions for the program in Figure 4.9.

- 1. compute the result of the addition and indicate the contents of the destination string;
- 2. state the final values of the A1 and A2 registers when RTS is being executed;
- 3. state what would happen if the ADDX.W -(A1),-(A2) at line 17 was replaced by ADDX.L -(A1),-(A2).

#### Solution

1. Results of the addition: A1 and A2 are decremented by two to \$00004004 and \$00005004. They refer to the least significant words (LSWs) of the two strings. The addition proceeds from the LSWs toward the most significant words (MSWs), as follows:

|                                            | MSW              | Next<br>LSW      | LSW              |          |
|--------------------------------------------|------------------|------------------|------------------|----------|
| Contents of $-(A1)$<br>Contents of $-(A2)$ | 1234<br>F878     | 5678<br>C800     | ABCD<br>A101     | added to |
| X carry bit 1                              | $\frac{1}{OAAD}$ | <u>1</u><br>1E79 | $\frac{0}{4CCE}$ | added to |

The final addition result is 0001 OAAD 1E79 4CCE, which is put into memory sequentially as shown. The final X bit is put at memory location \$00004FFE.

The final contents are

| Location   | Contents |
|------------|----------|
| \$00004FFE | 0001     |
| \$00005000 | 0AAD     |
| \$00005002 | 1E79     |
| \$00005004 | 4CCE     |

2. Final values of A1 and A2: A1 and A2 are decremented up to \$00004000 and \$00005000 due to the ADDX.W -(A1),-(A2) instruction (line 17). A2 is further decremented to \$00004FFE due to the MOVE.W D2,-(A2) instruction (line 24). Thus, the final values are

## A1 = \$00004000A2 = \$00004FFE

3. Replacement by the ADDX.L -(A1), -(A2) instruction: Long-word additions would be performed. Instead of three word additions, four word additions would be performed. A1 and A2 would be decremented to final values of \$00003FFE and \$00004FFC; however, this task might not be intended.

There are some important software considerations in the preceding example. Even if long-word operations are more efficient than word operations, they cannot be done correctly if the operation involves an odd number of words. Similarly, if an odd number of bytes needs to be added, the corresponding instructions should be byte oriented rather than word or long-word oriented.

If the ADDX.W -(A1),-(A2) instruction at line 17 is replaced by the SUBX.W — (A1), — (A2) instruction, the same software will perform multiprecision subtraction operations.

The X bit should always be cleared initially when dealing with operations of the multiprecision type.

#### Multiplication and Division Operations

The 68000 microprocessor has signed and unsigned multiply and divide (MULS, MULU, DIVS, DIVU) instructions. The destination is always a data register Dn. Multiplication of two 16-bit unsigned operands results in a 32-bit unsigned result in the destination data register. The unsigned operands can be up to  $65535 (2^{16} - 1)$  and the result can be up to 4,294,836,225 which is slightly less than  $2^{32}$ . In signed multiplication, the multiplier and the multiplicand operands can be positive or negative and can range between  $-2^{18}$  and  $+2^{15} - 1$  (or between -32768 and +32767). The largest positive or negative result can be up to plus or minus  $2^{30}$ . The negative result is expressed in twoscomplement notation. Since there is no possibility of obtaining any result beyond the

32-bit size, the carry and the overflow flags are always cleared to zero in multiplication operations. The N and Z flags are affected, based upon the result.

Division of a 32-bit destination operand (dividend) by a 16-bit source operand (divisor) results in a 16-bit remainder and a 16-bit quotient. The remainder and quotient occupy the upper and the lower 16-bit word positions of the 32-bit destination data register, respectively. The distinction between signed and unsigned division operations is similar to the distinction between signed and unsigned multiplication previously discussed. With division operations, it is possible to generate a quotient larger than the allowed 16 bits. In this circumstance, the overflow flag V will be set to indicate the overflow condition. Similarly, if division by 0 is performed, a zero-divide TRAP error will result.

In Figure 4.11, multiplication and division software is presented as a subroutine in a digital signal processing application. P, Q, and R are unsigned words contained in

| LINE ADDR                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LINE ADDR       ;multiply.src       9/25/88         2       ;       ;         3       ;P,Q,R unsigned words contained in         4       ;ascending memory addressed by AO.         5       ;W=P*Q in DO register. Divide W by         6       ;R, if R is nonzero value.         7       ;U=W/R in D1 register.         6       ;D2 is a working register.         9       OPT A         10       ORG \$1400         11       ;clear data registers |
| 12 00001400 4280       CLR.L D0         13 00001402 4281       CLR.L D1         14 00001404 4282       CLR.L D2         15       ;move P into D0 and multiply by Q                                                                                                                                                                                                                                                                                   |
| 16       ;to get W = P*Q in DO register         17 00001406 3018       START MOVE.W (A0)+,DO         18 00001408 COD8       MULU (A0)+,DO         19 0000140A 2200       MOVE.L DO,D1         20       ;check for nonzero value of R and                                                                                                                                                                                                             |
| 21       ;perform division to get U=W/R in D1         22 0000140C 3410       MOVE.W (A0),D2         23 0000140E 0C42 0000       CMPI.W #\$00,D2         24 00001412 6702       BEQ.S FINISH         25 00001414 82C2       DIVU D2,D1         26 00001416 4E75       FINISH RTS         27 00001418       END                                                                                                                                        |
| ASSEMBLER ERRORS = 0                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| SYMBOL TABLE                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| FINISH 00001416 NARG 00000000 START 00001406                                                                                                                                                                                                                                                                                                                                                                                                         |

FIGURE 4.11 Multiplication and division software for a typical 68000-based system (Example 4.5),

memory in an ascending order, as specified by the A0 register. The product  $W = P \times Q$ and the division result U = W/R are to be generated. These results are to be put in the D0 and D1 registers.

In order to accomplish the intended task, all the working data registers are cleared to an all-zero condition from line 12 to line 14. At lines 17 and 18, the P and Q words are sequentially read from the memory using the postincrement mode and are multiplied together to generate a 32-bit result in the D0 register. At line 19, the result is also moved into the D1 register.

From line 22 to line 25, word R is moved from memory into the D2 register and is checked for a nonzero value. In the case of a zero value, the division operation is skipped; otherwise, it is performed, with the division result in the D1 register. In any event, the software returns to the calling program by means of the RTS instruction at line 26.

The following example problem addresses software concerns in multiplication and division operations.

## Example 4.5 Multiplication and division.

Given P =\$FFFF, Q =\$0002, and R =\$0004 in sequential memory locations, using the software of Figure 4.11,

- 1. compute the values of W and U and indicate the contents of the D0, D1, and D2 registers and the state of the XNZVC flags when RTS is being executed;
- 2. repeat (1) if the MULU and DIVU unsigned instructions are replaced by the MULS and DIVS signed instructions;
- 3. explain how the calling program obtains the results.

#### Solution

1. Values of W, U, D0, and D1: Unsigned multiplication is performed as follows: P value from memory into D0 register \$FFFF \$0002 O value from memory \$0001FFFE => into D0 Multiplication  $W = P \times Q$ Unsigned division is performed as follows: \$0001FFFE W value from D0 into the D1 register \$0004 R value from memory into the D2 register \$7FFF => D1 low word Division U = W/R: quotient 0010 => D1 high word remainder Result of unsigned multiplication:

W in D0 =\$0001FFFE

Result of unsigned division:

U in D1 = \$00107 FFF

Nonzero positive quotient result in D0 with no overflow. As such,

XNZVC = -0000

2. Signed multiplication and division results: Signed multiplication and division are performed as follows;

> **Multiplication** \$FFFF (equal to -1) P value from memory into the D0 register 0002 (equal to +2) Q value from memory Signed multiplication  $W = P \times Q$ **SFFFFFFFE** (equal to -2) into D0 (sign extended to 32 bits and in twos-complement form) Division W value from the D0 register into D1 \$FFFFFFE (equal to -2) 0004 (equal to +4) R value from memory into the D2 register \$0000 (equal to 0) Division U = W/R: quotient

#### remainder

Result of signed multiplication:

W in D0 =\$FFFFFFFE

Result of signed division:

#### U in D1 = FFFE0000

Zero quotient result with no overflow. As such,

XNZVC = -0100

3. Results to the calling program: The multiplication and division results are communicated to the calling program through the contents of the D0, D1, and D2 registers. A zero value in the D2 register implies that the division has not been performed.

One of the operands (P in our case) is moved into the data register D0. This is necessary since multiplication and division instructions require that the destination operand be a data register. Also, the value of the R variable is checked before performing the division to avoid a division-by-zero error.

D1 low word \$FFFE (equal to -2) D1 high word

#### 4.4 SPECIAL INSTRUCTION GROUPS AND APPLICATIONS

The instruction set of the 68000 family of processors also includes multiple-decision instructions (DBcc). There are several instructions related to stack and address operands, such as LINK, UNLK, PEA, and LEA. There are also instructions to move multiple registers (MOVEM) and move peripheral data (MOVEP). In all of these cases, a single instruction performs multiple operations. This provides programming convenience and improves memory utilization.<sup>67</sup>

#### **Multiple-Decision Instructions**

Figure 4.12 illustrates the sequence of multiple-decision instructions (DBcc). These instructions are used to control loops. Upon entering the DBcc instruction loop, the specified condition is checked. If the condition is true, the program exits the loop and proceeds to the next instruction in the sequence. If the condition is false, then the specified data register is decremented and is checked to see whether it is less than zero (= -1). If it is less than zero, the program exits the loop and proceeds to the next instruction in the sequence. Otherwise, the program branches to the specified location. Operands decremented in Dn are of word size.



FIGURE 4.12 DBcc instruction sequence. (Courtesy of Motorola, Inc.)

Figure 4.13 consists of a string-compare program using the DBcc instruction scheme. At line 13, the Z flag is set to a 1 condition. This corresponds to a false condition for the DBNE instruction (decrement and branch if not equal to zero). At line 14, two string operands addressed by (A0)+ and (A1)+ are compared. At line 15, the DBNE instruction checks whether or not the BNE condition is true (BNE true leaves Z flag = 0). BNE true implies that the two operands are different. If BNE is true, the program exits the DBNE loop and proceeds to the next instruction (NOP at line 16).

| LINE A                | DDR                                                                  |                      |       |            |
|-----------------------|----------------------------------------------------------------------|----------------------|-------|------------|
| 1.4<br>15<br>16<br>17 | 00001000<br>00001004<br>00001004<br>0000100A<br>0000100C<br>0000100B | B388<br>56C9<br>4871 |       | STI<br>Agi |
| ASSEM                 | BLER ERRO                                                            | RS =                 | 0     |            |
|                       |                                                                      |                      |       | SYM        |
| AGAIN                 | 00001004                                                             | NARC                 | ; 000 | 0000       |

FIGURE 4.13 String-compare software for a 68000-based system using the DBcc instruction.

If BNE is false (Z = 1), the DBNE instruction decrements data register D1 and checks whether it has become negative (D1 < 0). If it is negative, the program proceeds to the next instruction (NOP at line 16). Otherwise, the program branches back to the 'AGAIN' loop (line 14).

The following example problem provides a review of the concepts we have just discussed concerning DBcc usage.

#### Example 4.6 DBcc usage.

The initial contents of the A0, A1, and D1 registers are as follows:

A0 = \$00004000 A1 = \$00005000

Memory between \$4000 and \$6000 is loaded with words \$AAAA. The program in Figure 4.13 is run.

1. Specify when the DBNE loop is terminated. What are the contents of the D1, A0, and A1 registers when the loop is terminated?

string.src 10/21/88 ;two strings addressed ; by AO and A1 are compared for sameness, using DBcc. ;D1 contains number of long ;words to be compared. OPT \$1000 ORG ;Set Z flag to 1 and start comparing strings ART ORI #\$D4,CCR JAIN CMPM.L (AD)+,(AL)+ DBNE D1, AGAIN NOP RTS END MBOL TABLE 00 START 00001000

D1 = \$00000 FF

2. Memory between \$4000 and \$4FFE is loaded with words \$0000; between \$5000 and \$6000 it is loaded with words \$AAAA. Repeat (1) using the same initial values for Dl, A0, and Al.

#### Solution

1. DBNE loop termination: Memory between \$4000 and \$6000 contains word patterns \$AAAA. As such, the comparison of memory addressed by A0 and Al renders the BNE condition false (since the data strings are the same). The program loops between lines 14 and 15 until the DI word is decremented below zero (to -1). At that point the DBNE loop is terminated.

Dl is decremented by FF + 01 = 100 = 256 times to get to -1. Thus, the loop is run \$100 times. Due to the long-word access and the postincrement addressing modes, the A0 and Al registers are incremented by 4 x \$100 = \$400, to \$4400 and \$5400, respectively. The final contents of the registers are

D1 =\$0000FFFF (in twos-complement form for -1)

A0 = \$00004400

A1 = \$00005400

2. DBNE termination with modified pattern: The first comparison itself renders the BNE condition true (since the compared data patterns are different). The DBNE loop is terminated at the first comparison. However, the A0 and A1 registers are postincremented to \$4004 and \$5004, respectively. The final contents of the registers are

> D1 =\$000000FF A0 = \$00004004A1 = \$00005004

Any other data register, or any other branching condition (DBEQ, DBGE, and so forth) can be used in the DBcc instruction. However, it is important to note that the appropriate flag bits must always be preconditioned to render the DBcc condition false at the start of the loop.

#### Address, Stack, and Multiple-Movement Instructions

The LEA (load effective address) instruction moves a 32-bit address operand into an address register An. The PEA (push effective address) instruction stacks a specified 32bit address operand. Both of these useful instructions do not affect the flags.

The LINK (link) instruction creates a work area on the stack and defines one of the address registers as a frame pointer (FP). This pointer is used to address the work area on the stack. The UNLK (unlink) instruction effectively removes the work space from the stack. The LINK and UNLK instructions are very useful in linking and unlinking the stack area in a multitasking environment in which several tasks are run by the processor, as scheduled by the operating system.

The MOVEM (move multiple registers) instruction moves data between the specified data (Dn) and address (An) registers and the memory, or vice versa. For register-tomemory transfers, control-alterable and predecrement addressing modes are allowed. For memory-to-register transfers, control-alterable and postincrement addressing modes are allowed. The data transfers take place in the sequence indicated below. For example, in the predecrement addressing mode, the first data transfer involves the A7 register and the last data transfer involves the DO register.

The MOVEP instruction moves data between a specified data register and alternate



even or odd bytes of memory, or vice versa. This instruction is very useful when dealing with 8-bit peripherals attached to the 68000 microprocessor. The memory can be addressed by the ARI with displacement addressing mode in the MOVEP instructions.

Figure 4.14 illustrates a typical multitasking type of software. At line 6, the actual address corresponding to TABLE is loaded into the Al register. At line 7, the PC relative addressing mode is used, and the offset corresponding to TABLE is loaded into the A2 register. At line 8, the contents of A2 are pushed to the stack.

The MOVEM instruction at line 9 moves the sequential word contents of memory addressed by Al into the Dl, D2, D3, and D4 data registers. The MOVEM instruction always follows a scanning order (D0-D7, A0-A7), regardless of the order in which they arc specified. The first register to be moved (in or out) is DO, then DI, and so on until A7. Thus, the specified registers are first matched with the set sequence, and then the data movement operation is conducted.

as follows:

- 1. Stack Al: Stack contents of Al. SP decrements by four.
- to Al. Al is now referred to as the frame pointer.
- This amounts to creating \$0C (12 bytes) of work space on the stack.

The MOVEM.W D1-D4, -\$8(A1) instruction at line 14 puts word operands from the Dl, D2, D3, and D4 registers in the newly created work area on the stack. This amounts to passing parameters Dl, D2, D3, and D4 to the other routines via the stack work area.

|    | <br>First |                                               |
|----|-----------|-----------------------------------------------|
| D6 | <br>D0    | Control and postincrement<br>addressing modes |
|    |           |                                               |
| Al | <br>A7    | Predecrement addressing<br>mode               |
|    |           |                                               |

The LINK Al, #—\$0C instruction at line 13 performs several sequential operations

2. SP --> Al: Move contents of stack pointer (SP) into Al. This effectively links the stack

3. (SP-\$0C) -> SP: Displace the SP by the specified amount of displacement (-\$0C).

LINE ADDR 11/8/88 ;special.src deals with special instructions OPT \$1000 ORG 4 ;task1 which initializes pointers 00001000 43F8 1024 4E71TASKÍ LEA TABLE, AL TABLE(PC), A2 00001006 45FA 001C LEA PEA (SA) 8 0000100A 4852 MOVEM.W (A1),D1-D4 0000100C 4C91 001E q ;link with A1 as frame pointer 1.0 ;and pass parameters to linked 11 stack area 1,2 A1,#-\$OC 13 00001010 4E51 FFF4 LINK 14 00001014 48A9 001E FFF8 MOVEM.W D1-D4,-\$8(A1) TASK2 15 0000101A 4EB8 102C 4E71 JSR UNLK A L 16 00001020 4859 RTS 17 00001022 4E75 \$1234,\$AACB TABLE DC.W 18 00001024 1234 AACB \$0026,\$001E DC.W 19 00001028 0026 001E ;task2 here takes the passed on 20 parameters and performs. TASK2 MOVEP.L -\$8(A1),D5 0000102C 0B49 FFF8 22 RTS 23 00001030 4B?5 END 24 00001032 0 ASSEMBLER ERRORS = SYMBOL TABLE NARG 0000000 TABLE 00001024 TASK1 00001000 TASK2 0000102C



At line 15 the program jumps to subroutine TASK2, starting at line 22. The MOVEP.L -\$8(A1),D5 instruction at line 22 moves four alternate even bytes from the work area of the stack into the D5 register. The RTS instruction at line 23 returns the program to the calling TASK1 program, which resumes at line 16.

The UNLK A1 instruction at line 16 performs the following sequential operations:

1. A1 --> SP: Restore stack pointer SP from frame pointer A1.

2. Unstack A1: Restore original value of A1. SP increments by four.

The preceding operations effectively unlink the stack and restore the original values of the frame and stack pointers. The RTS instruction at line 17 effectively returns this routine to the main calling program.

We will now review the special instructions by means of an example problem.

Example 4.7 Address, stack, and multiple-movement operations. CPU registers Dn and An are initialized to \$00000000. The stack pointer SP is initialized to \$000022FE. Using the software of Figure 4.14,

- 1. specify the contents of the A1, A2, and D1-D4 registers after the LEA and MOVEM instructions are executed through line 9;
- 2. show the contents of the stack during the execution of the preceding instructions;
- 3. indicate the contents of the D5 register when TASK2 (line 22) is executed.

#### Solution

1. Register contents: The LEA TABLE, A1 instruction loads A1 with \$00001024, which is the absolute address of TABLE. The LEA TABLE(PC),A2 instruction loads A2 with \$0000001C, which is the offset of TABLE from the current PC value. The current PC value corresponds to 00001008 (op. word location + 2). The MOVEM.W (A1),D1-D4 instruction loads the sequential words from TABLE into the data registers D1, D2, D3, and D4. The contents of the registers are

| A1 | = | \$<br>0 | 0 | 0 |
|----|---|---------|---|---|
| A2 | = | \$<br>0 | 0 | 0 |
| D1 | = | \$<br>0 | 0 | 0 |
| D2 | = | \$<br>0 | 0 | 0 |
| D3 | = | \$<br>0 | 0 | 0 |
| D4 | = | \$<br>Ð | Ð | 0 |

2. Stack contents: Figure 4.15 indicates the contents of the stack. The stack pointer decrements by two or four for word or long-word entries. The long-word contents of A2 are stored at \$000022FA. The original value of A1, which is to be used as a frame pointer, is stored next at \$000022F6. The current contents of the SP (\$000022F6) are transferred to A1. Thus, A1 is initialized to act as a frame pointer. Furthermore, the SP is initialized to a new value equal to \$000022EA (\$000022F6 displacement \$0C). This effectively provides a 12-byte work area on the stack.

Word contents from D1, D2, D3, and D4 are stored between locations \$000022EE and \$000022F4 in the work area by virtue of the MOVEM.W D1-D4, -\$8(A1) instruction. Notice that the frame pointer A1 is used to access the stack work area. The return address \$00001020 from the JSR instruction is stored in the new stack area at location \$000022E6.

When the UNLK instruction is performed, the SP and A1 registers are restored to their starting values of \$000022FA and \$00001024, respectively. The work area is effectively unlinked (removed) from the stack.

3. Contents of D5: The MOVEP.L -\$8(A1),D5 instruction moves four alternate bytes (long-word equivalent) from the effective address (EA) into the D5 register. The EA

01024 0001C 01234 **0AACB** 00026 00001E



is \$000022EE. The four alternate bytes are on the even byte boundary and correspond to \$12, \$AA, \$00, and \$00. These are loaded into the D5 register with \$12 in the most significant byte position. The contents of D5 are

#### D5 = \$12AA0000

.

There are some important software considerations in the preceding example problem. It should be ensured that the work area created (12 bytes) is sufficient for passing on the parameters between tasks. Also, the linking process should maintain the even boundaries for both the frame and stack pointers. While unlinking the stack, the frame pointer should be at the initialized value. Address register indirect (ARI) with displacement is a very convenient mode for accessing the stack work area without modifying the contents of the frame pointer. It is possible to use any address register as the frame pointer. FIGURE 4.16 Defining and using MACRO functions. (Courtesy of J. Salinger, FIU.)



### 4.5 MACROS IN SOFTWARE DEVELOPMENT

MACRO is an assembler utility. MACRO-function generation is essentially a preprocessor step in the assembly process which may result in a sequence of processor instructions. Proper parameters are passed in a MACRO-function call.

Figure 4.16 specifies the source code of a software routine containing a userdefined MACRO function EXMP with parameters X, Y, and Z. Source code following the MACRO declaration uses the processor instructions and the X, Y, and Z parameters. The ENDM assembler directive concludes the MACRO function.

The actual routine, written at the end of the program block, uses the MACRO function. The correspondence is as follows:

| EXMP.B         | 8, <mo< th=""><th>VE.B #\$01,I</th><th>D1&gt;,D2</th></mo<> | VE.B #\$01,I | D1>,D2 |
|----------------|-------------------------------------------------------------|--------------|--------|
| 1              | Ľ.                                                          | 1            |        |
| parameter =>\0 | Х                                                           | Y            | Z      |

When the source code is assembled, the assembler substitutes the actual instruction code for the MACRO function. The parameters are integrated into the code, as well. The assembled program is presented in Figure 4.17. It can be seen that the actual code has been substituted for the MACRO function.

Each time a MACRO function is used, the corresponding code is substituted. Although it takes up more program space, the MACRO program executes faster than the subroutines, since no stack activity is involved when the MACRO is used. Also, programmers can define several MACRO functions and develop software around them,

In the example problem that follows, we will review what we have learned about the MACRO.

```
LINE ADDR
                                   ;macro.src 11/11/88
                                       OPT
                                               $1400
                                       ORG
                                   ;defining macro EXMP
                                  EXMP MACRÓ X,Y,Z
                                       ADDQ.\0 #$X,Z
                                       NOP
                                       ENDM
    1 D
                                   ;ENDM above defines end of macro
    11
                                   ;using the macro EXMP
    12
                                       MÓVE.B #$FF,DO
    13 00001400 103C OOFF
                                       EXMP.B 8, <MOVE.B
    14 00001404
                                               #$01,D1>,D2
                                       ADDQ.B #$8,D2
    14 00001404 5002
                                       NOP
    14 00001406 4E71
                                       MOVE.B #$01,D1
    14 00001408 1230 0001
                                       NOP
    15 0000140C 4E71
                                       END
    16 0000140E
                     1
ASSEMBLER ERRORS =
```



Example 4.8 MACRO usage. Refer to Figures 4.16 and 4.17.

- 1. Specify where MACROS should be declared and written.
- 2. Specify how the MACRO function EXMP is assembled and coded.
- 3. Can a MACRO function be used several times in a software routine? Explain.

#### Solution

- 1. MACRO declaration: Most assemblers require that MACROS should be declared and written at the very beginning of the program. This ensures that the assembler is aware of them.
- 2. MACRO coding: The qualifier \0 corresponds to either byte, word, or long word. In our particular case, it corresponds to byte. The X parameter corresponds to 8. The Z parameter corresponds to the D2 register. The Y parameter corresponds to the MOVE.B #\$01,D1 instruction. When the code is assembled, the MACRO function EXMP is replaced by the actual sequence of instructions given in Figure 4.17.

# MACRO function is used, the entire code is substituted.

Several MACROS can be defined and used in the same program. A program written with MACROS is easy to read and follow. Most software engineers now use MACRO functions extensively. It is necessary to be aware, however, of the amount of program space available when using MACRO functions. MACRO directives are dependent upon the assembler. Even though most of them are similar, an assembler manual should be consulted for details on MACRO directives.

#### 4.6 SUMMARY

In this chapter, we introduced the assembly programming techniques with which to write 68000 assembly programs. Assemblers for the 68000 family of processors are available from several vendors. Most of the assemblers have similar directives. If the host computer has a different processor from the one for which the code is written, a cross assembler is used. Programs written in assembly language usually execute faster than programs written in such higher level languages as BASIC, FORTRAN, PASCAL, and C.

Assembler directives help in program development. In assembly language programming, symbols and labels are used in place of numbers and addresses. This greatly increases the readability of the programs. Symbols are usually specified at the beginning of the program to declare constants, address values, and variables. Labels are used within the body of the program.

Assembly-level programmers should be aware of different forms of instructions and addressing modes. They should be also familiar with the register resources and flag structure of the processor.

Most programming applications deal with some type of data movement, associated data processing, and decision making. The decision-making capability of the processor is used in program control applications. The software and the programming applications we considered in this chapter focused on program control.

Software engineers are programmers who are not only concerned with programming per se, but also with hardware resources, code integrity, execution timing, and optimization of the operating system.

Instructions such as DBcc, LINK, UNLK, MOVEM, and MOVEP are complex, each performing several operations. Use of these instructions makes for shorter, more efficient programs.

A MACRO is an assembler utility. A MACRO-function generation is a preprocessor step in the assembly process that may result in a sequence of processor instructions. When a MACRO function is used, the corresponding program code is substituted. The execution of a MACRO function does not involve any stacking operations; hence, it is taster than the execution of a subroutine. A MACRO function, however, uses more code memory.

3. MACRO usage: A MACRO function can be used several times in the program in which it is defined. The parameters may or may not be the same. Each time the

#### PROBLEMS

4.1 State the difference (if any) between(a) assemblers and cross assemblers;

(b) linkers and loaders.

- **4.2** Briefly outline the assembly process. What will happen if the program is written with instructions not known to the assembler?
- **4.3** Analyze the software in Figures 4.3 and 4.4. Does the assembled program contain the proper machine code for the listed instructions? Explain.
- 4.4 Write a program that will display the following message on the terminal:

MICROCOMPUTERS ARE GOOD TOOLS ;;

Assume there is a DISPLAY subroutine available. ASCII code for the character should be put into the D0 register and the DISPLAY subroutine called in order to display the character.

**4.5** Write an assembly program using 68000 mnemonics and the assembler directives discussed to accomplish the following objectives:

(a) start the program at location \$1200;(b) clear the memory words between \$2000 and \$2400.

- **4.6** Rewrite the software of Figure 4.5 to move \$200 long words of data from the location starting at \$6000 to the destination starting at \$4000. Start the program at \$00001000.
- **4.7** Write a routine to move \$2000 words from the location starting at \$6000 to the destination starting at \$5000. The memory contents are as follows:

| Location   | Contents |
|------------|----------|
| \$00006000 | \$0000   |
| 6002       | \$0001   |
| 6004       | \$0002   |
| :          | :        |

After the program is run, what is contained between \$5000 and \$5010?

- 4.8 Rewrite the software in Figure 4.5 using byte transfers instead of long-word transfers.
  - (a) Do byte transfers have a specific advantage over word or long-word transfers? Explain.
  - (b) What are the disadvantages of byte transfers compared to word or long-word transfers?
- **4.9** Rewrite the software in Figure 4.6 so that the smallest data element is at the lowest address. The data elements are given in Figure 4.7.
- **4.10** A 68000-based system operates on an 8-MHz clock. It is required to generate software delays in a digital control system application.
  - (a) Write a delay routine to generate a 1-millisecond delay.
  - (b) Using the software of (a), generate a 10-millisecond delay.
  - (c) Using the software of (b), generate a 1-second delay.

4.11 If the system was upgraded to a 68000 processor at a 16-MHz clock,

(a) Explain how the delay routines of Problem 4.10 are affected;

- (b) modify the software to obtain 1-millisecond, 10-millisecond, and 1-second delays.
- 4.12 Write 68000-based software as a subroutine to transfer the memory block between \$3000 and \$3200 to another block between \$3200 and \$3000 as shown, without modifying the data.



4.13 Repeat Example 4.4 in the chapter given the following memory contents:

| Source Address | Contents | <b>Destination Address</b> | Contents |
|----------------|----------|----------------------------|----------|
| \$00004000     | \$5786   | \$00005000                 | \$F88A   |
| 4002           | \$AAAA   | 5002                       | \$CCCC   |
| 4004           | \$0202   | 5004                       | \$1569   |
| 4006           | \$0987   | 5006                       | \$347E   |

- **4.14** Using the memory contents indicated in Problem 4.13, write 68000-based software to add the 4-word source string to the destination string, with the final results stored at the destination.
- **4.15** Using the memory contents indicated in Problem 4.13, write 68000-based software to subtract the source string from the destination string, with the final result in the destination.
- **4.16** Write 68000-based software as a subroutine to multiply two words stored at locations \$4000 and \$4002, with the result stored at location \$00004004. The initial contents of memory at \$4000 and \$4002 are \$0003 and \$8888, respectively. Use unsigned multiplication. What is the final result of the multiplication?

4.17 Repeat Problem 4.16 using signed multiplication.

- **4.18** Write software to perform unsigned division of X variable by Y variable. X and Y are stored at \$5000 and \$5004, respectively. The division result should be contained in the D2 register.
  - If X = AABBCC00 and Y = 0008, indicate the contents of D2 after the division.

4.19 Repeat Problem 4.18 using signed division.

- **4.20** Rewrite the software in Figure 4.13 using DBEQ in place of DBNE to perform the same task.
- 4.21 What will happen if the flags are not conditioned before DBcc conditions are used? Can two or more DBcc conditions be nested? Explain. What precautions should be taken in nesting DBcc, if it is possible.

4.22 Rewrite the software in Figure 4.14 replacing the LINK and UNLK instructions with equivalent instructions to accomplish the same task.

Which software-with LINK and UNLK or without-is more memory efficient? Why?

- 4.23 The LINK Al, #-\$0C instruction at line 13 of Figure 4.14 is replaced by LINK Al, #-\$10.
  - (a) Describe the corresponding modification for the UNLK Al instruction.
  - (b) Indicate the contents of the stack while the software is being executed.
  - (c) State the values of the Al, A2, and A7 registers after the LINK instruction is executed.
  - (d) State the contents of the Al, A2, and A7 registers after the modified UNLK instruction is executed.
- 4.24 Why are MACRO functions useful? Is there any limit to how many MACRO functions can be used? Explain.
- **4.25** Write a single MACRO function called CLEARD to clear all 32 bits of all the data registers.
- 4.26 Write a single MACRO function called CLEARA to clear all 32 bits of the A0-A6 address registers. (Note: Address registers cannot be directly cleared!)
- 4.27 A MACRO function called INIT uses ten 68000 instructions and occupies 32 words of program memory space. In a control system software application, the INIT function is used eight times with different parameters passed. When the software is assembled, how much program space is occupied by all the MACRO functions? Explain.

### ENDNOTES

- 1. Motorola, Inc. MC68000 Data Book. Phoenix, AZ: Motorola Technical Operations, 1983.
- 2. Harman, T., and Lawson, B. The Motorola MC68000 Microprocessor. Englewood Cliffs, NJ: Prentice-Hall, 1985.
- 3. Scanlon, L.J. The 68000: Principles and Programming. Indianapolis: Howard W. Sams, 1981.
- 4. Kane, G.; Hawkins, D.; and Leventhal, L. 68000 Assembly Language Programming. New York: McGraw-Hill, 1981.
- 5. Motorola, Inc. MC68000 16/32-Bit Microprocessor Programmer's Reference Manual, Fifth Edition. Englewood Cliffs, NJ: Prentice-Hall, 1987.
- 6. Motorola, Inc. MTT8: 68000 Course Notes. Phoenix, AZ: Motorola Technical Operations, 1987.
- 7. Andrews, M. Self-Guided Tour through the 68000. Englewood Cliffs, NJ: Prentice-Hall, 1984.
- 8. Stranes, T. "Design Philosophy Behind the M68000." Byte (Apr., May, Jun. 1983).

### Objectives

In this chapter we will study

General concepts of exception processing The exception table and vectors Reset exception processing Interrupt exceptions and applications Trap exceptions and applications Error exceptions and applications

# **CHAPTER**

# **68000 Exception Processing** Considerations

### 5.0 INTRODUCTION

An **exception** is a deviation from the normal processing sequence. The 68000 processor operates in the supervisor mode to handle exceptions. The supervisor mode is entered into automatically whenever the 68000 senses and services an exception routine request. An exception may be caused by an external hardware condition, an internal instruction, or an error condition.

Reset and interrupts are two exceptions caused by the system hardware. Internally generated exceptions include instructions, such as TRAPs and CHK, as well as error conditions, such as address error, bus error, privilege violation error, illegal instruction error, and zero-divide error. Other conditions, such as the TRACE mode of operation, also cause exceptions. The processor follows a specific sequence of operations in handling these exceptions.

Study of the exception processing concepts presented in this chapter will provide the necessary background to handle exception conditions in the 68000 family of processors. It will also help explain the user and supervisor modes of operation. The concepts apply to all 68000- and 68008-based systems; hence, no specific mention is made of the 68008. Exception processing for the 68010 and 68020 processors is similar to that for the 68000 processor. Due to additional resources and virtual memory schemes, however, exception processing for the 68010 and 68020 includes extra features. These features will be discussed in later chapters.

#### GENERAL CONCEPTS OF EXCEPTION PROCESSING 5.1

Exception processing is a privileged mode of operation in which the 68000 microprocessor operates in the supervisor mode. In this mode, the S bit in the status register is set to 1 and the SSP (supervisor stack pointer) controls the stack. Figure 5.1 indicates the 68000 exceptions with their established priority scheme and the relative timing for recognizing and starting the exception processing. Group 0 exceptions have the highest priority; Group 1 exceptions, the next highest; and Group 2 exceptions, the lowest priority. Within Group 0, the reset exception has the highest priority.

#### The Exception Vector Table and Exception Vectors

**Exception vectors** refer to memory locations from which the processor fetches the address of a routine to handle the exception. All exception vectors correspond to a long word. There are up to 256 such vectors, occupying 1 kilobyte of memory between \$000000 and \$0003FF. This dedicated memory is called the vector table.<sup>1</sup>

The vector table for the 68000 is presented in Figure 5.2. The two reset vectors, 0 and 1, are in the supervisor program space; all other vectors are in the supervisor data space.

| Priority<br>Group                     | Exception           | Particulars of Occurrence                                       |
|---------------------------------------|---------------------|-----------------------------------------------------------------|
| 0                                     | Reset               | Hardware-activated input for system master control              |
| (Highest<br>priority)                 | Address error       | Error in addressing operands                                    |
| , , , , , , , , , , , , , , , , , , , | Bus error           | Hardware memory access error                                    |
|                                       | Trace               | Single-step operation mode                                      |
| 1                                     | Interrupt           | Hardware inputs to processor to obtain pro-<br>cessor attention |
|                                       | Illegal instruction | Nonexistent instructions or op.codes used                       |
|                                       | Privilege violation | Privileged instructions used in user mode                       |
|                                       | TRAP                | Software initiated                                              |
| 2                                     | TRAPV               | Software initiated on overflow                                  |
| 2                                     | СНК                 | Data register beyond specified limits                           |
|                                       | Zero divide         | Division by zero encountered                                    |

Group 0: Current activity suspended at the end of the clock cycle. Exception processing starts within two clock cycles.

Group 1: Current activity suspended at the end of the bus cycle or the instruction cycle (for trace and interrupts). Exception processing starts before the next instruction.

Group 2: Current activity suspended within the instruction cycle. Exception processing starts as an instruction.

FIGURE 5.1 Exception grouping and priority scheme for the 68000 and the relative timing for exception processing.

#### Reset Exception Processing

Figure 5.3 illustrates the reset exception processing sequence. Reset is a hardwareactivated input to the processor. The reset exception initializes the system; hence, the processor does not copy or store any information before starting reset exception processing, as it does for other exceptions. On power-up reset, the processor goes into the supervisor mode, turns the trace condition off, and sets the interrupt mask level at 7 (highest). This is a cold start of the system. Reset input can also be activated by a pushbutton while the processor is running. In this case, the processor suspends current activity at the end of the clock cycle and reinitializes the system. This is referred to as a warm start. A cold start requires system stabilization and requires more time than a warm start.

In either case, the processor fetches the contents of vector 0 at location \$000000 from the vector table and loads them into the supervisor stack pointer (SSP). It fetches the contents of vector 1 at location \$000004 from the vector table and loads them into the program counter (PC). The processor then executes the reset exception routine be-

ginning at the location addressed by the PC. These two reset vectors are contained in the system ROM to retain their values when the power is shut off.<sup>2</sup>

If a bus error condition occurs while fetching vectors 0 or 1, the processor encounters a double bus fault condition and goes into a halt state. The hardware has to be de-

FIGURE 5.2 Exception vector table for the 68000. (Courtesy of Motorola, Inc.)

| Vector    | Address |     |       |                                |  |
|-----------|---------|-----|-------|--------------------------------|--|
| Number(s) | Dec     | Hex | Space | Assignment                     |  |
| 0         | 0       | 000 | SP    | Reset: Initial SSP             |  |
| 1         | 4       | 004 | SP    | Reset: Initial PC              |  |
| 2         | 8       | 008 | SD    | Bus Error                      |  |
| 3         | 12      | 00C | SD    | Address Error                  |  |
| 4         | 16      | 010 | SD    | Illegal Instruction            |  |
| 5         | 20      | 014 | SD    | Zero Divide                    |  |
| 6         | 24      | 018 | SD    | CHK Instruction                |  |
| 7         | 28      | 01C | SD    | TRAPV Instruction              |  |
| 8         | 32      | 020 | SD    | Privilege Violation            |  |
| 9         | 36      | 024 | SD    | Trace                          |  |
| 10        | 40      | 028 | SD    | Line 1010 Emulator             |  |
| 11        | 44      | 02C | SD    | Line 1111 Emulator             |  |
| 12        | 48      | 030 | SD    | (Unassigned, Reserved)         |  |
| 13        | 52      | 034 | SD    | (Unassigned, Reserved)         |  |
| 14        | 56      | 038 | SD    | Format Error                   |  |
| 15        | 60      | 03C | SD    | Uninitialized Interrupt Vector |  |
| 16-23     | 64      | 040 | SD    | (Unassigned, Reserved)         |  |
|           | 92      | 05C |       | -                              |  |
| 24        | 96      | 060 | SD    | Spurious Interrupt             |  |
| 25        | 100     | 064 | SD    | Level 1 Interrupt Autovector   |  |
| 26        | 104     | 068 | SD    | Level 2 Interrupt Autovector   |  |
| 27        | 108     | 06C | SD    | Level 3 Interrupt Autovector   |  |
| 28        | 112     | 070 | SD    | Level 4 Interrupt Autovector   |  |
| 29        | 116     | 074 | SD    | Level 5 Interrupt Autovector   |  |
| 30        | 120     | 078 | SD    | Level 6 Interrupt Autovector   |  |
| 31        | 124     | 07C | SD    | Level 7 Interrupt Autovector   |  |
| 32-47     | 128     | 080 | SD    | TRAP Instruction Vectors       |  |
|           | 188     | OBC |       | _                              |  |
| 48-63     | 192     | 0C0 | SD    | (Unassigned, Reserved)         |  |
|           | 255     | OFF |       |                                |  |
| 64-255    | 256     | 100 | SD    | User Interrupt Vectors         |  |
|           | 1020    | 3FC |       | -                              |  |



FIGURE 5.3 The 68000 reset exception sequence. (Courtesy of Motorola, Inc.)

bugged before the processor can be restarted. Hardware details relating to the reset, halt, and error conditions will be discussed in subsequent chapters.

~

### General Scheme of Exception Processing

A CULTURE OF STREET

As previously mentioned, exception processing is carried out in the supervisor mode. When an exception (other than the reset) occurs and is recognized, the processor suspends current execution as indicated in Figure 5.1. It makes a copy of the current status register (SR) to retain the original contents. If the processor is already in the supervisor mode due to an earlier exception, it continues in that mode to service the current exception. However, if the processor is in the user mode, it moves into the supervisor mode to service the current exception. For exception processing, the stack used is the supervisor stack.3

The general exception sequence is presented in Figure 5.4. After setting the S bit to 1 for the supervisor mode, the trace condition is turned off (T = 0). For interrupts, the interrupt mask level is set to the new value. The processor stacks the current PC and the copied SR. For address and bus error exceptions, additional processor information is stacked. The processor then fetches the appropriate exception-vectored address from the



vector table and loads it into the PC. It then begins exception processing starting at the new address.<sup>4</sup>

The last instruction of an exception routine (other than a reset routine) is RTE (return from exception). When the RTE instruction is encountered, the processor restores the stored PC, SR, and any other information relating to the suspended process from the stack. It then resumes the execution of the suspended process.

We will now review the reset and general exception sequences with the help of an example problem.

## Example 5.1 Reset and general exception sequences.

For a particular 68000-based system, the contents of the vector table are as shown:

| Vector<br>Number | Hex<br>Address | Hex Word<br>Contents | Assignment<br>Type |
|------------------|----------------|----------------------|--------------------|
| 0                | 000000         | 0000                 | SSP on reset       |
| -                |                | 0A00                 |                    |
| 1                | 000004         | 0000                 | PC on reset        |
| -                |                | 8400                 |                    |
| 2                | 000008         | 0000                 | PC on bus error    |
| -                |                | 8800                 |                    |
| :                |                | :                    | :                  |

- 1. Where are the SSP and the top of the stack initialized on power-up?
- 2. Where does the reset routine start? Why?
- **3.** Are the contents of the stack memory of any particular value at the power-up reset condition? Why?
- 4. What are the primary differences between the reset and the general exception sequences?

#### Solution

1. Initialization of the SSP and top of the stack: Long-word contents corresponding to vector 0 at location \$000000 are \$00000A00. These are fetched by the processor and loaded into the SSP, which refers to the top of the stack. Thus, the top of the stack is initialized at

#### SSP = \$00000A00

2. Reset routine: Long-word contents corresponding to vector 1 at location \$000004 are \$00008400. These are fetched by the processor and loaded into the PC. Thus, the reset routine starts at

#### PC = \$00008400

- 3. Initial contents of the stack: For the reset operation, the initial contents of the stack on power-up are of no consequence. This is because the reset routine initializes the system; it does not depend on any stacked contents.
- 4. Differences between reset and general exception sequences: The following are the primary differences:

| Reset Exception                                                | General Exception                                                                   |
|----------------------------------------------------------------|-------------------------------------------------------------------------------------|
| Processor registers are not stacked.                           | PC and copied SR are at least stacked.                                              |
| Two reset vectors to initialize SSP and PC.                    | Only one vector, the contents of which are loaded into PC.                          |
| No RTE at the end of the reset routine, and no return address. | RTE at the end of the routine returns<br>the processor to the suspended<br>program. |

At the end of a successful reset routine, the system is properly initialized and is ready to perform other operations and handle exception conditions. We will now study the details of the other general exceptions.

## 5.2 INTERRUPT EXCEPTIONS AND APPLICATIONS

Interrupts are hardware signals from the I/O devices and systems to obtain the attention of the processor. These signals are encoded and applied as IPL2, IPL1, and IPL0 inputs to the processor. Figure 5.5 illustrates the 68000 interrupt structure. A level 7 interrupt  $(\overline{IPL2} \ \overline{IPL1} \ \overline{IPL0} = 0 \ 0 \ 0)$  has the highest priority and a level 1 interrupt  $(\overline{IPL2} \ \overline{IPL1} \$  $\overline{IPL0} = 1 \ 1 \ 0$ ) has the lowest. A level 0 interrupt signifies that no interrupt is pending.<sup>5</sup>



FIGURE 5.5 The 68000 interrupt structure and interface.

#### Interrupt Mask Levels

The 12, II, and 10 bits of the system byte in the status register specify the interrupt mask level. A higher level interrupt than the mask level can interrupt the processor and be recognized. Any interrupt lower than or equal to the mask level will not be recognized; it is effectively masked out. The interrupt mask level is automatically adjusted to the interrupt level that is being recognized and serviced.

Interrupts 1 through 6 are maskable. Interrupt 7 is a nonmaskable interrupt (NMI). Even if the mask level is at 7, if an interrupt 7 occurs and satisfies the timing requirements, the processor must recognize and service it. When an interrupt is recognized, the processor generates an interrupt acknowledge cycle by activating the appropriate address lines (A1-A23) and the function code outputs FC2, FC1 and FCO.

An external decoder decodes this cycle and provides the corresponding interrupt acknowledge signals (IACK1-IACK7) to the interrupting devices. Hardware and timing details of these signals will be discussed in subsequent chapters.

Interrupt processing is similar to general exception processing. On recognizing the interrupt, the processor suspends current activity at the end of the instruction and makes a copy of the status register. The processor sets the S bit to 1 and moves into the supervisor mode. It then sets the interrupt mask level to a new value corresponding to the interrupt being recognized. The processor stores the current PC and the copied SR on the supervisor stack. The stored PC points to the next instruction to be executed in the suspended routine. The processor then fetches the appropriate interrupt-vectored address from the vector table and begins the interrupt exception processing starting at that vectored address.

#### Autovector and User Vector Methods

There are two methods, known as the autovector method and the user vector method, to obtain the interrupt vectors and service the interrupting device. In response to the IACK signal from the processor, the interrupting I/O device generates the /VPA signal for the autovector method, or the DTACK signal for the user vector method.

In the autovector method, the processor obtains the address for the interrupt service routine directly from the vector table. Vector 25 corresponds to a level 1 interrupt and vector 31 corresponds to a level 7 interrupt. The processor reads the contents of the appropriate vector location and loads them into the PC. It begins the interrupt exception routine starting at that address.

In the user vector method, an interrupting device provides an 8-bit user vector number Vn (vector numbers 64 through 255) on the data bus D0-D7. The processor reads this vector number and configures the vector location by multiplying the vector number by 4. The processor reads the contents of this location and loads them into the PC. It then begins the interrupt exception routine starting at that address.

A higher level interrupt can always interrupt a lower level interrupt. The processor suspends the lower level interrupt, services the higher level interrupt, and then resumes the suspended interrupt processing. Interrupts are nested and serviced in this manner.<sup>6</sup>

The following example problem provides a review of interrupt exception processing.

#### Example 5.2 Interrupt exception processing. Figure 5.6 illustrates an interrupt-driven 68000-based system and the exception vector table contents. The processor is executing a user program as follows:

| PC                                           |
|----------------------------------------------|
| \$001200<br>\$001202<br>\$001204<br>\$001206 |
|                                              |

The internal register values are

SSP = \$00000A00

```
Mnemonic
MOVE.W DO.D3
CLR.W DD
NOP
JMP
       (A4)
```

USP =\$0000C400 SR = \$0200

FIGURE 5.6 (a) Interrupt-driven 68000-based system and (b) contents of the vector table (Example 5.2).



(a)

| Vector # | Туре                  | Hex address | Word Contents |
|----------|-----------------------|-------------|---------------|
| 0        | Reset SSP             | 000000      | 0000<br>0A00  |
| 1        | Reset PC              | 000004      | 0000<br>8400  |
| :        | ;                     | :           | :             |
| 29       | Interrupt 5<br>(auto) | 000074      | 0000<br>8A00  |
| 30       | Interrupt 6<br>(auto) | 000078      | 0000<br>8B00  |
| :        | :                     | :           | :             |
| 64       | User vector           | 000100      | 0000<br>9A44  |
| <br>:    | :                     | :           | :             |

- 1. Interrupt 5 from the printer occurs as the processor is executing the CLR.W D0 instruction. Will it be recognized? What are the levels of the IPL2, IPL1, and IPL0 signals for interrupt 5?
- 2. Indicate the contents of the SR and the stack after interrupt 5 is recognized and is ready to be serviced. Where does the interrupt 5 exception routine start if it is autovectored?
- 3. When interrupt 5 is being serviced and the PC is pointing to the next instruction at \$00008A4C, interrupt 7 occurs. Indicate the contents of the SR and the stack after

the interrupt is recognized and is ready to be serviced. Assume the user byte remains at the same value.

4. Assume interrupt 7 provides user vector Vn = 64 =\$40. Where does the interrupt 7 exception routine start?

#### Solution

Figure 5.7 shows the contents of the status register and the supervisor stack.

FIGURE 5.7 (a) Status register contents and variations and (b) supervisor stack and contents as interrupts occur (Example 5.2).





the user mode (S bit = 0) and the interrupt mask level is at 2 (I2 I1 I0 = 0 1 0). Interrupt 5 is higher than the mask level; thus, it is recognized. IPL2, IPL1, and IPL0 inputs to the processor are active low. To signify interrupt 5, their logic levels are

 $\overline{\text{IPL2}} \ \overline{\text{IPL1}} \ \overline{\text{IPL0}} = 0 \ 1 \ 0$ 



1. Interrupt 5: Initially, the SR contains \$0200. This implies that the processor is in

2. SR and stack after interrupt 5: The processor completes the CLR.W DO instruction, which sets the Z flag to 1 and the other flags to zero, before attending to interrupt 5. Thus, the user byte of the SR becomes \$04. The system byte remains at \$02. The processor internally copies these contents of the SR (= \$0204) and moves into the supervisor mode by setting the S bit to I. It then changes the interrupt mask level to 5. Thus, the SR becomes \$2504 after interrupt 5, as indicated in Figure 5.7(a).

The PC points to the next instruction (NOP) at location \$00001204. The processor stores this PC value and the copied SR on the supervisor stack, as indicated in Figure 5.7(b).

The autovector number for interrupt 5 is 29, corresponding to vector location \$000074, as indicated in Figure 5.6(b). The contents of this location (= 00008A00) are loaded into the PC. Thus, the interrupt 5 exception routine starts at

#### PC location = \$00008A00

3. Interrupt 7: Interrupt 7 is nonmaskable; thus, it is recognized. The processor sus pends the interrupt 5 routine, makes a copy of the SR, and changes the system byte to 27 (S bit = 1; mask level = 7). The SR after interrupt 7 is 2704, as indicated in Figure 5.7(a).

The processor stacks the current PC value (= \$00008A4C) and the copied SR (= \$2504), as indicated in Figure 5.7(b).

4. User vector for interrupt 7: User vector number Vn = 64 =\$40 for interrupt 7 corresponds to vector location  $0100 (= 4 \times 40)$ , as indicated in Figure 5.6(b). The contents of this location (= \$00009A44) are loaded into the PC. Thus, the in terrupt 7 exception routine starts at

#### **PC location = \$00009 A44**

As previously discussed, the last instruction at the end of an exception routine is RTE. When RTE is encountered at the end of the interrupt 7 exception routine, the processor restores the stored SR and PC (= \$2504 and \$00008A4C, respectively), which correspond to the suspended interrupt 5 processing, from the stack. The processor then resumes the suspended interrupt 5 processing.

Similarly, when RTE is encountered at the end of the interrupt 5 exception routine, the processor restores the earlier stored SR and PC (= \$0204 and \$00001204, respectively), which correspond to the suspended user program, from the stack. The processor then resumes the suspended user program.

### 5.3 TRAP EXCEPTION PROCESSING AND APPLICATIONS

Traps are exceptions caused by instructions. There are 16 TRAP instructions: TRAP #0 through TRAP #15, corresponding to the vector numbers 32 through 47 of the vector table.

#### Using System Resources in the Supervisor Mode via Traps

Most system resources are under the control of the operating system. In the 68000 family of processors, operating system resources can only be handled in the supervisor mode. TRAP instructions are similar to software interrupts; they can be used within a program to move into the supervisor mode and use the system resources.

Similarly, traps can be used to move into the supervisor mode to use privileged instructions. Essentially, traps provide a convenient means of intercommunication between the user and supervisor modes.<sup>7</sup>

#### Trap Software Routines and Applications

Trap exception processing is similar to interrupt processing. When a TRAP instruction is encountered, the processor concludes the current instruction, copies the SR internally, and moves into the supervisor mode by setting the S bit to 1. The T (trace) bit is turned off. The processor then stores the current PC and the copied SR on the supervisor stack. The stored PC points to the next instruction after the TRAP instruction in the program.

The processor then fetches the appropriate TRAP-vectored address from the vector table, loads it into the PC, and begins the TRAP exception processing starting at that address. RTE is the last instruction in any TRAP exception routine. When the RTE instruction is encountered, the processor restores the stored PC and SR and resumes the original program.

The TRAPV instruction generates an exception (vector 7) if an overflow condition is detected in the previous operation. The TRAPV instruction is similar to the TRAP instruction, except that TRAPV does not require an operand field and will generate an exception only if the overflow (V) flag is set.

The user stack pointer (USP) is considered a system resource and can only be initialized in the supervisor mode. Figure 5.8 consists of an operating system routine writ-



```
TRAP.src 12/31/88
TRAP type exception routine
;which initializes the USP
;with the contents of the
;A2 register
  OPT
           $1200
  ORG
;load contents of A2 into USP
;and return
   MOVE.L A2,USP
   NOP
  RTE
   END
```

ten as an exception routine that initializes the USP. This routine starts at \$00001200. The MOVE.L A2,USP instruction at line 11 initializes the USP with the contents of the A2 register. The RTE instruction at line 13 returns control back to the calling program.

The user can call this program via a TRAP instruction. The user must load the starting address of the exception routine at the vector table location corresponding to the TRAP being used. The user must also pass the parameter value for the USP (through the A2 register) while calling the TRAP routine.

The following example problem focuses on the software details of TRAP instruction use.

#### Example 5.3 Using TRAP exceptions.

Figure 5.8 shows an operating system exception routine starting at \$00001200. The routine initializes the USP.

- 1. In order to call the routine, the TRAP #1 instruction must be used. Develop an appropriate software routine that uses TRAP #1 and initializes the USP at \$00002000.
- 2. Is there any priority scheme associated with TRAP instructions? Explain.

#### Solution

**1.** Software using TRAP #1: The TRAP #1 vector number is 33, which corresponds to vector address location \$0084 in the vector table of Figure 5.2. The user can load the starting address of the USP initialization routine (= \$00001200) into the vector location and use the TRAP #1 instruction to call the routine.

A software routine to accomplish the task in question is presented in Figure 5.9. Between lines 14 and 16, \$00001200 is loaded into vector location \$0084. At lines 20 and 21, an initialization value of \$00002000 is loaded into the A2 register (to be passed on as the USP parameter for the TRAP #1 routine), and the TRAP #1 routine is called. The TRAP #1 exception routine (Figure 5.8) loads the passed-on value (\$00002000) into the USP and returns to the original calling program. The JMP (A3) instruction at line 23 causes an indirect jump to the user I/O routine, the address of which is contained in the A3 register. 2. Priority for TRAP instructions: There is no priority scheme for TRAP instructions. This is because the TRAPs are software instructions which are executed in the sequence of their occurrence in the program.

| LI                         | NE ADDR                          |              |              |      |                                          |
|----------------------------|----------------------------------|--------------|--------------|------|------------------------------------------|
| 15<br>16<br>17<br>18<br>19 | 00001100<br>00001106<br>0000110C | 227C<br>2149 | 0000<br>0084 | 1500 | MOVE<br>MOVE<br>;call<br>;the u<br>;pass |
| 20<br>21<br>22             | 00001110<br>00001116             |              | 0000         | 2000 | MOVE<br>TRAP                             |
|                            | 00001118<br>0000111A             | 4ED3         |              |      | ;jump<br>JMP<br>END                      |

FIGURE 5.9 TRAP1 routine initialization and use by the calling programs (Example 5.3).

In general, any TRAP #n (n = 0-15) can be used in the preceding example as long as the starting address of the exception routine is loaded into the appropriate vectored address location. Each time a TRAP routine is called, the current PC and the copied SR are stored on the supervisor stack. The user should ensure that sufficient supervisor stack space is available if several TRAP #n instructions are to be nested.

#### 5.4 ERROR-RELATED EXCEPTIONS

The 68000 processor handles error conditions as exceptions in the supervisor mode. Operating system routines are written in the supervisor mode for the 68000 family of processors. Error-handling routines to help the user can be written by the operating system designer.

Upon detecting an error condition, the processor suspends current execution, copies the SR, and moves into the supervisor mode. It turns off the trace and stacks the copied SR and the current PC (which points to the next instruction in the suspended routine). In certain error conditions (bus and address errors, for example), additional

```
1.src 12/31/88
1 routine initializes
stack pointer
$00000000 refers to
beginning of vector table.
1 routine starts at $00001200.
ontains the address of user I/O
ines.
    $001100
TRAP1 address into
or location $0000084.
EA.L #$00000000,A0
EA.L #$00001200,A1
E.L A1,$0084(AD)
TRAP1 routine to initialize
user stack pointer at $00002000.
this stack parameter through A2.
EA.L #$00002000,A2
    #1
to user I/O routines through (AB)
    (EA)
```

processor information is saved on the stack. The processor then goes to the corresponding vector location in the vector table, fetches the address of the exception routine, and executes it in response to the detected error condition.

### Illegal Instruction, Unimplemented Instruction, and Privilege-Violation Conditions

Illegal Instruction The first word of an instruction is always an op.word. When the fetched op.word does not correspond to any of the defined op.words, an illegal instruction error condition occurs. Three bit patterns always force an illegal instruction error condition for the 68000 family of processors: \$4AFA, \$4AFB, and \$4AFC. The first two patterns are reserved for Motorola; the third is for general use. This exception returns control to the operating system in case of any illegal op.codes, thus preventing unpredictable operation. The vector number for the illegal instruction is 4.

Exception processing for illegal instructions is similar to that for traps. After the instruction op.code has been fetched and decoding attempted, the processor recognizes that the execution of an illegal instruction is being attempted. It then starts the exception processing.

Unimplemented Instruction Op.word patterns with bits 15 through 12 equaling 1010 or 1111 (\$A or \$F) are distinguished as unimplemented instructions. When these codes are discovered by the processor, unimplemented exception processing results. Higher level processors, such as the 68020, use these op.codes for coprocessor support and emulations. The vector numbers for the two conditions mentioned are 10 and 11.

**Privilege Violation** In order to provide system security, some instructions for the 68000 dealing with the status register, stack pointer, and system operation are privileged. Examples are the following:

AND immediate to SR (for status register violation); EOR immediate to SR (for status register violation); MOVE to SR (for status register violation); OR immediate to SR (for status register violation); MOVE USP (for stack pointer violation); RTE (return-from-exception instruction); RESET (reset instruction); STOP (stop-the-processor instruction).

These instructions may be used only in the supervisor mode. An attempt to use any of them in the user mode results in a privilege-violation exception.<sup>577</sup>

Exception processing for a privilege violation is similar to that for an illegal instruction. Control is returned to the operating system in case of any privilege violation, thus protecting system resources and routines from being modified by the user. The vector number for the privilege-violation condition is 8.

#### Uninitialized and Spurious Interrupt Exceptions

Uninitialized Interrupt In the case of the user vector method for interrupt processing, if the 68000 family I/O device is not initialized, it provides default vector number 15 during the interrupt acknowledge cycle. The processor recognizes this as an uninitialized interrupt condition and initializes exception processing.

Spurious Interrupt A spurious interrupt condition results from a bus error during the interrupt acknowledge cycle. The processor recognizes this condition and initiates spurious interrupt exception processing. The vector number for a spurious interrupt is 24. Exception processing for uninitialized and spurious interrupts is similar to trap exception processing. These two exceptions return control to the operating system in case of an interrupt vector error, thus preventing any ambiguous interrupt processing.

### Zero-Divide, CHK, and Trace Exception Conditions

Zero-Divide Exception A zero-divide exception occurs when division by zero is attempted during the execution of a divide instruction. This exception prevents the processor from going into an indefinite loop. The vector number for a zero-divide exception is 5.

CHK Exception A CHK exception occurs when the data register associated with the CI IK instruction is out of bounds. This exception returns control to the operating system if boundaries are crossed in case of a multitasking operation. The vector number for the CHK exception is 6.

Trace Exception A trace exception occurs when the T (trace) bit in the system byte of the status register is set. When the T bit is set at the beginning of program execution, the processor executes one instruction at a time and goes to trace exception. In trace exception routines, the results of the instruction just executed are displayed. Essentially, the processor goes into a single-step mode for software debugging. The vector number for the trace exception is 9.

The zero-divide, CHK, and trace exceptions occur during program execution. They prevent the processor from getting hung up on errors. Appropriate exception routines that provide proper feedback to the user should be written by the operating system designer so that exception conditions can be handled efficiently.

ceptions studied thus far.

### **Example 5.4** Error conditions and exceptions.

A 68000-based system is operating in the user mode. In each of the following situations, state whether an error or exception condition will be generated. Indicate the exception vectors, as appropriate.

We will now present an example problem to review the error conditions and ex-

1. The processor tries to execute an op.code corresponding to the CLR.W A4 instruction.

- 2. The processor tries to execute MOVE.W D6,SR.
- 3. The processor tries to execute the following sequence:

CLR.L DO SO,OO UVTO

Solution

- 1. CLR.W A4 instruction: This is an illegal instruction, since the address register direct addressing is not defined in the CLR instruction. The processor recognizes this as an illegal instruction error condition and initiates the exception processing sequence. The vector number for the illegal instruction is 4.
- 2. MOVE.W D6,SR instruction in user mode: Moving information into the status register while in the user mode results in a privilege-violation error condition. The processor recognizes this and initiates the privilege-violation exception sequence. The vector number for the privilege violation is 8.
- 3. CLR.L D0 and DIVU D0,D2 instructions in sequence: The CLR.L D0 instruction clears the D0 register. The DIVU D0,D2 instruction attempts a division-by-zero operation, since D0 has been cleared earlier to the zero condition. The processor recognizes this and initiates the zero-divide exception sequence. The vector number for a zero-divide exception is 5.

In response to the zero-divide error in the preceding example, an exception routine will display a message:

division by zero attempted

Suppose this routine starts at address \$00001400. This starting address should be loaded as a long word at location \$014 (corresponding to vector number 5) during system initialization. When the zero-divide error condition occurs, the exception routine will be executed.

## Address and Bus Error Conditions

Address Error An address error occurs when the 68000 processor attempts to access a word or long-word operand or an instruction at an odd address. When the processor discovers an address error, it aborts the current bus cycle, copies the SR, and goes into the supervisor mode. It stores the copied SR, the PC (pointing to the possible next instruction), and some additional information on the supervisor stack, as shown in Figure 5.10. The supervisor stack frame for a bus error is similar.<sup>5,6,7</sup>

|             | b15 b14 b13 · · · · · ·                                        | ••• b4  | b3    | b2     | 61    | ь0   |
|-------------|----------------------------------------------------------------|---------|-------|--------|-------|------|
| SSP ⇒       | Special status word (see below)                                | R/W     | / I/N | FC2    | FC1   | FC0  |
|             | Access address Hig                                             | h word  |       |        |       |      |
|             | Access address Low                                             | v word  | word  |        |       |      |
|             | Instruction register Op.                                       | , word  |       |        |       |      |
|             | Status register                                                |         |       |        |       |      |
|             | Program counter High                                           |         |       |        |       |      |
|             | Program counter Low                                            |         |       |        |       |      |
|             | $R/W \Rightarrow$ Read/write: write = 0 and read = 1           |         |       |        |       |      |
|             | I/N $\Rightarrow$ Instruction/not: Instruction = 0 and not = 1 |         |       |        |       |      |
|             | FC2 FC1 FC0 ⇒ Function codes                                   |         |       |        |       |      |
| FIGURE 5.10 | Supervisor stack frame for address and b                       | ous err | ors f | or the | e 68( | 000. |

The stored instruction register points to the instruction in which the address error was detected. The fault access address refers to the actual physical address where the address error occurred. The special status word refers to the actual internal conditions of the processor at the occurrence of the address error. This information is useful in the software debugging process.

An address error exception prevents the 68000 processor from any word misalignment in accessing instructions or operands. The vector number for the address error is 3.

Bus Error A bus error occurs when the processor attempts to access nonexistent memory or I/O and the interface logic activates BERR (bus error) input to the processor, as shown in Figure 5.11. Time-out circuitry in the interface logic generates the BERR



input to the processor instead of the normal /DTACK if the memory or I/O fail to respond within a given time.

Bus error exception processing is similar to address error processing. A bus error exception prevents the processor from indefinitely waiting for nonexistent memory or I/O to respond. The vector number for the bus error is 2.

The following example problem will enhance our understanding of address and bus errors.

#### Example 5.5 Address and bus errors.

For the 68000-based system of Figure 5.11, memory and I/O are physically contained between \$000000 and \$0FFFFF. The initial values of the registers are

SSP = \$00000A00 USP = \$00002000 SR = \$0600

The program of Figure 5.12 is run.





- 1. The conditions given will result in an error exception sequence when the program is run. What type of error is involved? Explain.
- 2. Indicate the stack format for the error exception in (1).
- 3. The ADD.L (A0),D0 instruction at line 8 (Figure 5.12) is replaced with the ADD.L (A1),D0 instruction, and the program is rerun. Will there be an error condition now? How does the stack look for this error?

#### Solution

- 1. Error condition: There is a bus error condition. It occurs during the execution of the ADD.L (A0),D0 instruction at line 8, while trying to access the source operand. The effective address of the source operand [\$00FFAA00 (contents of A0)] is beyond the available memory and I/O range, and is nonexistent. The interface logic therefore generates the /BERR signal, and the processor initiates the bus error exception sequence.
- 2. Stack format: On detecting the bus error condition, the processor moves into the supervisor mode. The supervisor stack is used for storing the processor registers and the operands.

Figure 5.13 illustrates the supervisor stack format and the contents for the bus error exception: the PC corresponds to the next instruction (SUBQ.L #04,D0). SR is the copied status register at the time of the exception. Stored op.word \$D090 corresponds to the instruction where the bus error occurred. The fault access address (\$00FFAA00) is the actual physical address where the bus error fault condition occurred.

| FIGURE 5.13 Supervisor stack contents for the bus error condition (Example 5.5). | SSP          | Memory word             | Stored operand details                   |
|----------------------------------------------------------------------------------|--------------|-------------------------|------------------------------------------|
|                                                                                  | \$0009F2     | 0019                    | Special status word (see below)          |
|                                                                                  | \$0009F4     | 0 0 F F                 | Fault access address (high word)         |
|                                                                                  | \$0009F6     | A A 0 0                 | Fault access address (low word)          |
|                                                                                  | \$0009F8     | D 0 9 0                 | Instuction op.word                       |
|                                                                                  | \$0009FA     | 0 6 0 0                 | Copied status register                   |
|                                                                                  | \$0009FC     | 0 0 0 0                 | Program counter (high word)              |
|                                                                                  | \$0009FE     | 100E                    | Program counter (low word)               |
|                                                                                  | \$000A00     | xxxx                    | Top of stack (contains previous operand) |
|                                                                                  |              |                         | : :                                      |
|                                                                                  | Special stat | us word \$0019 correspo | nds to                                   |
|                                                                                  | b15 · ·      | <i>.</i> . t            | b5 b4 b3 b2 b1 b0                        |
|                                                                                  |              |                         | R/W I/N FC2 FC1 FC0                      |
|                                                                                  | 0 • •        |                         | 0 1 1 0 0 1                              |
|                                                                                  |              |                         |                                          |

The stored special status word signifies that the fault occurred while reading a data operand from user data space.

3. ADD.L (A1),D0 instruction: There is an address error condition. It occurs while trying to access the source operand. The effective address of the source operand [\$OO0OOCC3 (contents of Al)] is within the physical memory, but is odd. The processor recognizes this long-word access at an odd address as an address error and initiates the address error exception sequence.

The supervisor stack format for the address error is similar to that for the bus error.

When the stack frame for the bus and address errors in the preceding example is examined, the fault conditions can be analyzed and corrected. In 68010/12 processors, additional information is stored on the stack for possible virtual memory implementation, which we will study later, in conjunction with those processors. In 68020/30 processors, word and long-word data operands can be accessed at an odd address without generating an address error condition.

#### **Double Bus Fault Condition**

This is a catastrophic failure in which the processor comes to a complete halt. The double

bus fault occurs when

a bus error occurs while accessing the reset vectors;

- a bus error occurs during the exception processing sequence of an earlier bus or address error; or
- there are nested combinations of bus error and illegal instruction exception

processing operations. The processor also activates the HALT output line, which halts any peripherals connected to the halt line. This prevents a system runaway condition. Software and hardware must be debugged and the system reinitialized to recover from a double bus fault condition.<sup>21417</sup>

#### 5.5 SUMMARY

An exception condition is a deviation from the normal condition. The 68000 processor handles the exception in the supervisor mode.

External hardware conditions, such as reset and interrupts, cause exceptions. So do instructions, such as TRAPs and CHK, under certain conditions. Error conditions, such as privilege violations, illegal instructions, unimplemented instructions, zero-divide operations, bus errors, and address errors, also cause exceptions.

Appropriate software routines written as part of the operating system in the supervisor mode handle exceptions. On the occurrence of any type of exception, the processor moves into the supervisor mode.

One kilo byte of memory between \$000000 and \$0003FF of a 68000-based system corresponds to the exception vector table. This table contains the starting addresses of the exceptions. On the occurrence of an exception, the processor fetches the starting address of the corresponding exception routine from this table.

The reset exception has the highest priority; it initializes the system resources and conditions. Stacking of the registers is not done during reset exception processing. Vector 0 corresponds to the supervisor stack pointer and vector 1 corresponds to the program counter for the reset exception.

Hardware interrupts from the external I/O and peripherals are meant to obtain the attention of the processor. The interrupts follow a priority scheme involving the three interrupt mask bits of the status register. Interrupt 7 is at the highest priority level and is a nonmaskable interrupt (NMI). Interrupts 6 through 1 are at successively lower priority levels and are maskable. They can be masked by setting the interrupt mask level in the system byte of the status register to a higher level. Interrupt 0 implies that there is no pending hardware interrupt.

TRAP instructions are similar to software interrupts; they are used to move from the user mode into the supervisor mode. This allows users to employ system-level resources

A privilege-violation error condition occurs when an attempt is made to use privileged instructions in the user mode. If an instruction code that does not correspond to any of the permissible codes is used, an illegal instruction error condition occurs. When an attempt is made to access nonexistent memory or I/O, the external logic activates /BERR (bus error) input to the processor. The processor recognizes this and goes into bus error exception processing. When a word or long-word access attempt is made at an odd address, an address error condition occurs.

The processor does not stack any information for reset exception processing. For In the case of nested errors, a double bus fault condition causes the processor to go into a complete halt state. During the halt state, the address and data buses are tristated,

all other exceptions, the copied SR and the PC (pointing to the next instruction at the time of the exception) are stored on the supervisor stack. In the case of address and bus error conditions, additional information is also stored. This corresponds to the fault address, the instruction that caused the fault condition, the special status word, and so forth. and the control signals negated. The system must be debugged and reinitialized in order to recover from a double bus fault condition.

#### PROBLEMS

- 5.1 How soon does exception processing begin for the following conditions: (a) reset from pushbutton;
  - (b) illegal instruction;
  - (c) zero-divide.
- 5.2 How many total exception vectors are in the vector table? How many different exceptions are serviced?
- 5.3 Explain why the reset exception takes two vectors, whereas all other exceptions take only one.

- 5.4 What is the primary difference between a cold start and a warm start? Are there any differences in terms of the exception processing with cold and warm starts?
- 5.5 For a 68000-based system, suppose it is necessary to initialize the supervisor stack at \$00002000. The reset routine should start at \$00001600. Indicate the contents of vector table locations \$000 through \$008.
- 5.6 Write a reset routine under the conditions of Problem 5.5 to reinitialize the SSP at \$00003000, the USP at \$00002400, and to set the interrupt mask level at 4. In addition, an interrupt 6 exception routine starting at address \$00004200 is to be loaded into the appropriate autovectored location. The last instruction in the routine should be a STOP #\$2200 instruction.
- 5.7 Consider the interrupt-driven system of Figure 5.14.
  - (a) The processor is executing a user program and the PC is pointing to the next instruction at \$00001244. At that instant, interrupt 4 from a printer occurs. Will it be recognized? Explain.
  - Indicate the contents of the stack, if the interrupt is recognized. (b) Interrupt 4 is user vectored with a vector number 72. Interrupt 4 service routine's
  - starting address is \$00001620. What is the vector location address and what are the contents of that location?
  - (c) What are the contents of the status register soon after the recognition of interrupt 4?



5.8 Suppose the system of Figure 5.14 is servicing interrupt 4 from the printer. The user byte of the status register is \$04. Interrupt 7 from the dynamic memory controller occurs as the processor is executing the MOVE instruction in the following program segment:

| pC value   | Instruction     |                         |  |
|------------|-----------------|-------------------------|--|
| \$00001680 | MOVE.L<br>ROL.W | #\$002211CC,D2<br>#2,D2 |  |

(a) Will the interrupt be recognized? Why or why not?

- (b) If the interrupt is recognized, what are the contents of the supervisor stack?
- (c) Interrupt 7 is autovectored. Where does the processor go to obtain the interrupt 7 exception routine starting address?
- 5.9 In a particular application, the SSP and USP are initialized at \$000A00 and \$0009E0, respectively.

- of an interrupt?
- (b) How many interrupts can be nested without running out of supervisor stack space?
- 5.10 Specify the advantages and disadvantages of the autovector and user vector methods. How many total user vectors are there?
- follows:

Indicate the contents of the exception vector table containing the preceding information. Clearly identify the vector numbers and vector locations.

**5.12** What are the vector numbers and vector locations for the uninitialized and spurious interrupt exceptions?

- 5.13 What are the vector numbers and vector locations for TRAP #3, TRAP #5, TRAP #9, and TRAP #14.
- 5.14 Suppose it is necessary to run the operating system routine shown in Figure 5.8 as TRAP #4, which begins at a starting address of \$0000140C. What modifications should be made in this software routine so that it will be executed when the user calls TRAP #4?
- 5.15 Modify the software of Figures 5.8 and 5.9 so that the USP is initialized at \$00004000 when TRAP #4 (starting at \$0000140C) is called by the user routine.
- **5.16** Write a TRAP #6 routine (for a 68000 system) starting at \$000016E0 to reset the system peripherals, go into a stop condition, and load SR with \$2400. Indicate the contents of the appropriate vector locations.
- 5.17 Write a TRAP #7 routine starting at \$00001700 to input a character from an I/O location at \$0000F800 into the DO register and echo the character to an output terminal at \$0000F802. Indicate the contents of the appropriate vector locations.
- 5.18 List the errors that cause exceptions in a 68000-based system in the order of their priority, from highest to lowest. Which errors are software related and which are hardware related?
- 5.19 A 68000-based system is in the user mode. In the following cases specify any error or exception conditions:

| (a) MOVE.B | A1.A2  |
|------------|--------|
| (b) CLRA.W | A3     |
| (c) DC.W   | \$FF00 |

(d) ANDI.W #\$FF0O.SR

(a) How much minimum stack space is required to store the appropriate registers in the event

5.11 In a particular 68000-based system, the starting addresses of the autovectored interrupts are as

- interrupt 1: \$00001040
- interrupt 2: \$00001080
- interrupt 3: \$000010C0
- interrupt 4: \$00001100
- interrupt 5: \$00001140
- interrupt 6: \$00001180
- interrupt 7: \$000011C0
- What are the primary differences between these two interrupt conditions?
- Is TRAP #15 higher, lower, or at the same priority level as TRAP #0? Explain.

- **5.20** With reference to Problem 5.19, specify the vector numbers and vector locations in case of error conditions.
- **5.21** A system is in the user mode. Identify any error or exception conditions when the software that follows is executed. Initially, DO = \$00000004; DI = \$0000FFCC.

| LOOP | MOVE.L | D1,D2    |
|------|--------|----------|
|      | DIVU   | DO,D2    |
|      | DBEQ   | DO, LOOP |
|      | NOP    |          |
|      | STOP   | #\$0700  |

Where does the processor go in case of an error condition?

**5.22** A 68000-based system memory and I/O are between \$000000 and \$00FFFF. The initial values of the registers are

A0 = \$000FFEEA A1 = \$0000CDEF A2 = \$00000CCC SR = \$0404

Specify whether any error conditions occur in each of the following:

(a) MOVEM.L D0-D7, (A0)
(b) MOVEP.L (A1), D2
(c) CLR.L \$07(A2)

**5.23** A 68000-based system memory and I/O are between \$000000 and \$00FFFF. The initial values of the registers are

A0 = \$000FFEEA A1 = \$0000CDEF A2 = \$00000CCC SR = \$0404 USP = \$00002000 SSP = \$00000A00 DO = \$00000003

Specify whether there is an error condition in any of the cases that follow. If so, specify the error, the exception vector number, and the vector location. Also indicate the contents of the stack using the initial values as stated.

- (a) ADD.B (A0),D2
- (b) SWAP Al
- (c) CLR.L \$04(A2,D0.W)
- **5.24** Identify four different instances of a double bus fault condition in a 68000-based system.
- 5.25 Refer to the supervisor stack contents given in Figure 5.15.
  - (a) The processor is executing an interrupt 6 routine. When RTE is executed as the last instruction of this routine, where does the processor go? Explain.
  - (b) Another RTE is executed at the end of the resumed routine of (a). Where does the processor go? Explain.
  - (c) The routine that was suspended when interrupt 6 occurred must have been of a certain type. State the type and explain.

FIGURE 5.15 Supervisor stack contents (for Problems 5.25, 5.26, and 5.27).

| $SSP \approx \$0000096C =>$ | 2300                 | Current top of stack           |
|-----------------------------|----------------------|--------------------------------|
|                             | 0000                 | -                              |
|                             | 0000<br>1600         |                                |
|                             | 0004                 |                                |
|                             | 0000                 |                                |
|                             | 0000<br>213C<br>xxxx |                                |
|                             | xxxx                 | Top of stack at initialization |
|                             |                      | -                              |

- **5.26** In Figure 5.15, the SSP pointing to the top of the stack at initialization must have been what initial value? Why?
- **5.27** Due to a memory read error, the entry \$213C in the stack in Figure 5.15 has been read as \$213B. Where will the processor go to execute the next instruction? Explain.

#### **ENDNOTES**

- 1. Motorola, Inc. MC68000 Data Book. Phoenix, AZ: Motorola Technical Operations, 1983.
- Harman, T., and Lawson, B. *The Motorola MC68000 Microprocessor*. Englewood Cliffs, NJ: Prentice-Hall, 1985.
- 3. Scanlon, L.J. The 68000: Principles and Programming. Indianapolis: Howard W. Sams, 1981.
- Motorola, Inc. MC68000 16/32-Bit Microprocessor Programmer's Reference Manual, Fifth Edition. Englewood Cliffs, NJ: Prentice-Hall, 1987.
- Motorola, Inc. MTT8: 68000 Course Notes. Phoenix, AZ: Motorola Technical Operations, 1987.
- 6. Andrews, M. Self-Guided Tour through the 68000. Englewood Cliffs, NJ: Prentice-Hall, 1984.
- 7. Stranes, T. "Design Philosophy Behind the M68000." Byte (Apr., May, Jun. 1983).

## CHAPTER

6

# 68000 Hardware Considerations and Design Applications

#### Objectives

In this chapter we will study:

Hardware signals and buses of the 68000 Memory and I/O interface schemes and design Control interface schemes System-level busing schemes, such as the VERSA and the VME

#### 6.0 INTRODUCTION

In chapters 1 through 5, our focus was on the general architectural features and software aspects of the 68000 microprocessor. In this chapter, we will explore the hardware aspects of a 68000-based system.

Generally speaking, all microprocessors have an address bus for addressing instructions and operands, a data bus for data and operand transfers, and a control bus for control and timing signals. A **bus** is a collection of signals with similar properties. The 68000 processor has additional busing features for asynchronous and synchronous data transfers, interrupt and DMA (direct memory access) transfer operations, and system control.

The material in this chapter will provide the necessary background to understand the essential hardware features of the 68000. In addition, it will provide insight into the

system control and error detection schemes associated with the 68000 family. These processors follow memory-mapped I/O schemes, in which the processor communicates with an I/O device as if it were one of the memory locations. The word *memory* will be used to refer to both memory and I/O in our discussions, unless otherwise specified.

#### 6.1 68000 HARDWARE SIGNALS AND FUNCTIONS

Figure 6.1 indicates the pin configuration of the 68000, and Figure 6.2 is a system representation. The 68000 is contained in a 64-pin DIP package or a 68-pin grid-array package. It is fabricated with either NMOS or CMOS technology. For the corresponding signal properties, appropriate data books should be referenced.<sup>1,2</sup>



FIGURE 6.1 The 68000 pin configuration.



FIGURE 6.2 System representation of the 68000.

#### Address, Data, and Asynchronous Buses for the 68000

The address bus is a 23-bit (A1-A23) unidirectional tristate bus, capable of addressing 8 megawords (or 16 megabytes) of data or operands. It provides the address of the operands during the read and write bus cycles. During a read bus cycle, the processor reads the instructions or source operands from the memory. During a write bus cycle, the processor writes data into the memory. During the interrupt acknowledge cycle, address lines Al, A2, and A3 provide information about the level of interrupt being serviced. Address lines A4 through A23 are set to a high logic level.

The data bus is a 16-bit (D0-D15) bidirectional tristate bus, capable of transferring byte- or word-sized operands between the processor and the memory (or I/O).

The **asynchronous bus** is used to control asynchronous data transfers of varying response times between the processor and the memory or I/O units. For the 68000 processor, the asynchronous bus consists of five control signals:

- 1.  $\overline{AS}$  (address strobe output);
- 2.  $R/\overline{W}$  (read/write output);
- 3. LDS (lower data strobe output);
- 4. UDS (upper data strobe output); and
- 5. DTACK (data acknowledge input).

An  $\overline{AS}$  signal signifies that the address information on the address lines is valid. An R/W signal at a high level signifies a read bus cycle; at a low level, it signifies a write bus cycle.

When LDS is low, data on lines D0 through D7 are selected. This data element is known as the lower byte (or the odd byte). When UDS is low, data on lines D8 through D15 are selected. This data element is known as the upper byte (or the even byte). When both  $\overline{\text{LDS}}$  and  $\overline{\text{UDS}}$  are low, data on lines D0 through D15 are selected. Figure 6.3 illustrates the data-selection scheme.<sup>3</sup>

| UDS  | LDS  |
|------|------|
| High | High |
| High | Low  |
| Low  | High |
| Low  | Low  |

FIGURE 6.3 LDS and UDS signals selecting lower or upper data bytes or word of memory (or I/O).

The 68000 processor activates the /AS, R/\*W, /LDS, and/or /UDS signals along with the address information for a read or a write bus cycle. The addressed memory (or the I/O system) activates an acknowledge signal /DTACK to the processor, while providing the data to the processor (read cycle), or accepting the data from the processor (write cycle). The processor does not terminate the bus cycle and insert wait states until DTACK has been generated. Thus, depending upon the speed of response of the memory or the I/O system, data transfers between the processor and these systems vary in the time they take. Consequently, we have an asynchronous data-transfer mechanism in the 68000 family of processors.<sup>4</sup>

### Function Code Outputs

The function code outputs FC2, FC1, and FC0 provide status information about the processor, as indicated in Figure 6.4. These outputs from the processor can be used to distinguish between the user and supervisor modes of operation and between program and data space within each mode. When the processor accesses the reset vectors (vectors 0 and 1) or the program code, it is in the program space. Any other operand access is in

Data Selection Data not selected Lower byte (D0-D7) selected Upper byte (D8-D15) selected Word (both bytes: D0-D15) selected

| FC2                                  | FCI                                  | FC0                                  | State                                                                                                                                             | Mode                                                                         |
|--------------------------------------|--------------------------------------|--------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|
| 0<br>0<br>0<br>0<br>1<br>1<br>1<br>1 | 0<br>0<br>1<br>i<br>0<br>0<br>1<br>1 | 0<br>1<br>0<br>1<br>0<br>1<br>0<br>1 | Reserved for Motorola<br>Data space<br>Program space<br>Reserved<br>Reserved for Motorola<br>Data space<br>Program space<br>Interrupt acknowledge | User<br>User<br>User<br>Supervisor<br>Supervisor<br>Supervisor<br>Supervisor |

FIGURE 6.4 Function code outputs; associated states and modes.

the data space. External logic can be used to decode these function code conditions and prevent supervisor memory from being accessed when the processor is in the user mode.<sup>5</sup>

#### Other Buses and Signals

The **synchronous bus** in a microprocessor is used to control synchronous or timed data transfers between the processor and the memory or I/O. In the 68000, this bus is used to interfere with the earlier 6800 family of synchronous peripherals. In a synchronous operation, data transfers take place within a fixed time frame, as opposed to variable timing in the case of asynchronous operation. The synchronous bus for the 68000 consists of three signals used for 6800 peripheral control:

- 1. E (enable clock) output;
- 2. /VMA (valid memory address) output; and
- 3. /VPA (valid peripheral address) input.

The E clock is one-tenth the frequency of the 68000 clock input and is used to synchronize the 6800 family or similar synchronous peripherals used with the 68000. A VMA signal indicates to the 6800 family devices that there is a valid memory add<u>ress on</u> the address lines and that the device should be synchronized to the enable clock. VPA indicates to the processor that the addressed device is a synchronous device. Also, during an interrupt acknowledge cycle, /VPA is used by the interrupting device to indicate an autovectoring mechanism to the processor.

The **arbitration bus** is used for direct memory access (DMA) data transfers. In such transfers, the processor releases the address, data, and control buses, and external logic controls them for direct data transfers. DMA transfers are faster than memory transfers requiring processor intervention, since no time is needed for instruction fetch cycles. The arbitration bus for the 68000 consists of three arbitration signals:

- 1. BR (bus request input);
- **2.**  $\overline{BG}$  (bus grant output); and
- 3. BGACK (bus grant acknowledge input).

The external logic requests the bus release by activating the  $\overline{BR}$  line. The processor responds to this request by activating its  $\overline{BG}$  output. The requesting device then acknowledges the response by activating the  $\overline{BGACK}$  and subsequently takes possession of the buses. The DMA transfers take place until the external logic releases the buses and  $\overline{BGACK}$ .

The interrupt control bus is used by the external devices to request the attention of the processor. The processor recognizes these requests and services them in a levelpriority scheme. The interrupt control bus for the 68000 consists of encoded  $\overline{IPL2}$ ,  $\overline{IPL1}$ , and  $\overline{IPL0}$  inputs (IPL stands for interrupt priority level).

The system control bus is used for system initialization and error control. For the 68000, it consists of the  $\overrightarrow{RESET}$  and  $\overrightarrow{HALT}$  bidirectional signals and the  $\overrightarrow{BERR}$  (bus error) input signal.

The clock input signal advances the processor through the sequential states of operation. For the 68000, each read or write bus cycle (without wait states) consists of four clock cycles. Any wait states are integral multiples of clock cycles.

The 68000 operates on a 5-volt power supply. Two pins are allocated for the  $V_{CC}$  input and two for the ground connection. Some of the signals we mentioned may go into a tristate or high-Z condition under special conditions. Figure 6.5 is a summary of the 68000 signals.

We will now review the hardware aspects of the 68000 by means of an example problem.

#### Example 6.1 68000 signals and definitions.

The 68000 microprocessor employs a memory-mapped I/O approach, in which memory and I/O appear to be similar.

- 1. With 23 address lines and LDS and UDS signals, how many total memory and I/O bytes can be addressed? Explain.
- 2. Can the processor use the synchronous bus for I/O transfers and the asynchronous bus for memory transfers simultaneously?
- 3. What will be the values of the FC2, FC1, and FC0 outputs while the processor is fetching interrupt autovector 6. Why?

#### Solution

1. Memory and I/O bytes: With 23 address lines, 8 megawords  $(2^{23} = 8,388,608)$  of memory and I/O together can be addressed. LDS and UDS signals further select an odd or even byte within the word.

Total memory and I/O addressing = 8 megawords = 16 megabytes

| RESET RESET                        | BERR       | INPUT        | LOW  | õ       | ON  |
|------------------------------------|------------|--------------|------|---------|-----|
|                                    | SET        | INPUT/OUTPUT | MOT  | ON      | ON  |
| HALT HALT                          | LT         | INPUT/OUTPUT | TOW  | ON      | ON  |
| ENABLE                             | ш          | OUTPUT       | HIGH | ON<br>N | 0N  |
| VALID MEMORY ADDRESS               | <u>MA</u>  | OUTPUT       | TOW  | ON      | YES |
| VALID PERIPHERAL ADDRESS VALID     | PA         | INPUT        | TOW  | NO      | ON  |
| FUNCTION CODE OUTPUT FC0, FC1, FC2 | FCI,<br>C2 | DUTPUT       | HIGH | ON      | YES |
| CLOCK CLK                          | <b>LK</b>  | INPUT        | HDIH | NO      | ON  |
| POWER INPUT (2) V <sub>cc</sub>    | cc         | INPUT        | ŀ    |         |     |
| GROUND (2) GND                     | DN         | INPUT        | 1    |         |     |

|                              |                            |              |                 | H       | Hi-Z        |
|------------------------------|----------------------------|--------------|-----------------|---------|-------------|
|                              | Memoric                    | Input/Output | Active<br>State | On HALT | On BGACK    |
| Signal Name                  |                            | OI ITTDI IT  | HIGH            | YES     | YES         |
| ADDRESS BUS                  | A1-A25                     |              |                 | 002     | VES         |
| SIJA BUS                     | D0-D15                     | INPUT/OUTPUT | HIGH            |         |             |
|                              | N N                        | OUTPUT       | LOW             | QN      | YES         |
| ADDRESS STROBE               |                            |              |                 |         |             |
| READ/WRITE                   | R/W                        | DUTPUT       | WRITE-LOW       | Q<br>N  | XEX         |
|                              |                            | At WEDI IT   | MOT             | on      | YES         |
| UPPER AND LOWER DATA STROBES | UDS, LDS                   |              |                 |         |             |
|                              | DTACK                      | INPUT        | TOW             | ON      |             |
| DATA TRANSFER ACKNOWLEDGE    |                            |              | /MO 1           | QN      | on          |
| RIIS REOUEST                 | BR                         | TUANI        |                 |         |             |
|                              | BG                         | OUTPUT       | LOW             | DN      |             |
| BUS GRANT                    |                            |              | MOL             | 0X      | 0<br>N<br>N |
| BUS GRANT ACKNOWLEDGE        | BGACK                      | INANI        |                 |         |             |
| INTERUPT PRIORITY LEVEL      | <u>IPLO, IPLI,</u><br>IPLZ | INPUT        | ROW             | ON<br>N | ON<br>N     |

FIGURE 6.5 Signal summary for the 68000. (Courtesy of Motorola, Inc.)

- 2. Simultaneous usage of buses: Synchronous and asynchronous buses cannot be used simultaneously. Address and data buses are required for each type of data transfer. The data transfers must be done one at a time.
- 3. FC2, FC1, and FCO values: Interrupt servicing activity takes place in the supervisor mode. Interrupt vectors are in the supervisor data space (refer to Chapter 5 and Figure 6.4).

**FC2 FC1 FCO** = 1 0 1

For the 68008 processor, there are 20 address lines (A0-A19) and 8 data lines (D0-D7). This processor can address a total of 1 megabyte of memory and I/O. There is only one data strobe DS in place of the /LPS and /UDS signals. /VMA and /BGACK signals are dropped, and the /IPLO and /IPL2 interrupt signals are integrated for the 48-pin dip package (for the 52-pin, they are left intact). All other hardware features of the 68008 are similar to those of the 68000 processor.

#### 6.2 MEMORY AND I/O INTERFACE SCHEMES

Memory is an integral part of any computer system. The decoded address bus provides selection signals, called chip select (CS) signals to the memory system. Additional selection signals, called **chip enable** (CE) signals, are used for further selection of memory systems. Data transfers take place between the processor and the selected memory on the data bus. The 68000 processor uses the asynchronous bus to control these transfers. The I/O interface is similar to the memory interface.

#### Memory-Device Types and Memory Concepts

Memory devices can be classified as random access or sequential access. The randomaccess read/write memory (RAM) and the read-only memory (ROM) systems are basically random access, in which access time to all memory locations is the same. RAM and ROM devices are used for the main operating memory of the computer system. The RAM system is suitable for information storage and retrieval; however, it is a volatile system and loses information if the power is turned off.

The industry uses either static or dynamic RAM devices. The static RAM device consists of an array of flip-flops contained in a matrix. Each flip-flop acts as a memory cell. Static memory devices are available in 8K-by-8 and 32K-by-8 configurations as of this writing. A 32K-by-8 RAM device has 256K (262,144) flip-flops in it.

The dynamic RAM (DRAM) stores information in the form of a charge on the gate of a single MOS transistor. The dynamic memory cell needs to be refreshed periodically so that charge information will not be lost due to decay. The DRAMs are denser than the static RAM devices (usually by a factor of four). One-megabit DRAM devices are common as of this writing. The DRAM interface is more complex than the static RAM interface. Moreover, the failure rate of DRAM-based systems is greater than that of static RAM-based systems. In the DRAM systems, however, error detection and

correction schemes are employed to increase the reliability of the memory system. The access time of the MOS RAM (static and dynamic) is approximately 100 to 200 nanoseconds.

nism are generally preferred.

ROM devices are nonvolatile and retain information even if power to the device should be disconnected. For mask-programmable ROMs, the code and data contents are programmed at the factory and cannot be changed. The erasable and programmable **ROMs** (EPROMs) can be programmed with the help of EPROM programmer systems. The EPROMs are nonvolatile in the system operation. However, they can be erased using ultraviolet light or high-voltage pulses and reprogrammed with a new code and data using EPROM programmer systems. EPROM devices in denominations of 64K by 8 and 256K by 8 are common, with access times of approximately 100 to 200 nanoseconds.

NMOS and CMOS RAMs (static and dynamic) are widely used. For fast-access memories, bipolar static RAMs are preferable. The ROMs and EPROMs are basically of the MOS type. With ultralow-power CMOS RAMs and a battery backup, it is possible to obtain a nonvolatile memory system.

milliseconds).

In this chapter we will concentrate on the commonly used memory system implementation with static RAM and ROM/EPROM devices.

#### Address Decoding, Strobing, and Memory Selection

The 68000 system memory is word organized, consisting of even and odd bytes, as illustrated in Figure 6.6. Higher order address bits are decoded and the CS signals are generated. Each CS signal selects a range of memory. Within the range, the same CS signal activates both the even and the odd memory units. /UDS and /LDS signals independently activate the CE inputs of the even and the odd byte sections of the memory. R/W drives the memory units for read or write selection. The low-order address lines are directly connected to the memory devices in order to select the actual location within a selected memory device.

The lower (or odd) memory byte is connected to data lines D0-D7. The upper (or even) byte is connected to data lines D8-D15. An /AS (address strobe) signal enables the decoder logic and initiates the memory bus cycle. The /AS, /LDS, /UDS, and the control signals occur in a fixed sequence.

#### Read and Write Timing Considerations

Read Bus Cycle Figure 6.7 illustrates read bus-cycle timing for word operation, Each clock cycle is divided into two S-states. SO is the starting state of a bus cycle. During SO, all the strobe signals are at their inactive level. The address and data buses

If simple interface and high reliability are required, static RAM systems are preferred. For high-density applications, DRAM systems with the error correction mecha-

Sequential memory systems are nonvolatile and are suitable for backup applications. They have a larger memory capacity, but also longer access times (up to several



FIGURE 6.6 Memory configuration in the 68000.





are in their tristate condition. During SI, the processor puts address information on the address bus and sets R/\*W to a high level to signify a read bus cycle. During S2, the strobes (/AS, /LDS, and /UDS) are activated.

One clock cycle (states S3 and S4) is allowed for the external logic to respond. At the end of S4, the processor expects /DTACK. One clock cycle after the occurrence of /DTACK, the processor accepts data on lines D0-D15 and internally latches it (at the end of S6, in this case). During S7, the processor deactivates all of the strobe signals and address lines. The memory system recognizes this event and deactivates /DTACK. This concludes the read bus cycle, whereupon the processor is ready for the next bus cycle.

The read bus cycle for byte operation is similar. The processor activates /LDS for a low (or odd) byte or /UDS for a high (or even) byte, but not both. Without any wait states, the read bus cycle for a word or byte operation takes four clock cycles.<sup>6</sup>

*Write Bus Cycle* Figure 6.8 illustrates write bus-cycle timing for word operation, which is similar to read bus-cycle timing. During state S2, the processor activates the address strobe AS and sets R/W to a low level to signify a write cycle. During S3, the processor puts data on the data bus. During S4, the processor activates the /LDS and /UDS signals. When the memory accepts this data, it is expected to activate /DTACK by the end of state S4. If /DTACK occurs by the end of S4, the processor waits one more clock cycle (until the end of S6) and deactivates the strobe signals and the address and data lines. This completes the write bus cycle. For byte operations, the processor activates only /LDS or /UDS, for odd or even bytes.



**Read-Modify/Write Bus Cycles** The read-modify/write operation is required by instructions such as TAS (test and set). In **TAS instruction**, the operand is read from a location into the processor. It is tested, modified, and written back at the same location.<sup>7</sup>

A. 1

The read-modify/write bus timing is illustrated in Figure 6.9. The address content during the operand read and write cycles remains the same. Data content may change, however.



FIGURE 6.9 The 68000 read-modify/write bus-cycle timing for word operation. (Courtesy of Motorola, Inc.)

Wait States Clearly, DTACK is expected by the end of the S4 state for read and write bus cycles. If DTACK does not occur by the end of S4, the processor inserts a full clock cycle as a wait state, at the end of which  $\overline{\text{DTACK}}$  is checked for.

The processor inserts wait states until either DTACK or a BERR (bus error) signal occurs. If BERR occurs, the processor aborts the bus cycle and goes into bus error exception processing, as discussed in previous chapters.

## Timing Considerations of Asynchronous Inputs

DTACK is considered an asynchronous control input to the processor. The processor samples such asynchronous signals on the falling edge of the clock. On the next rising edge, the processor internally validates the sampled signal. On the next falling edge, the sampled signal is acted upon by the processor. Thus, there is an inherent clock-cycle delay to act upon a sampled asynchronous signal. From the read bus cycle of Figure 6.7, it can be observed that DTACK has been sampled at the end of S4 (a falling edge), internally validated at the end of S5 (a rising edge), and externally acted upon by the processor at the end of S6 (a falling edge). This clock-cycle delay is intended to eliminate uncertainties in bus operation. The other asynchronous inputs to the 68000 processor are BERR, BR, BGACK, HALT, RESET, and VPA, as indicated in Figure 6.10. The following example problem provides a review of read and write bus cycles and timing.



Example 6.2 68000 read and write bus-cycle timing. The 68000 in the system of Figure 6.6 is operating at a 10-MHz clock frequency. Timings for the read and write cycles are indicated in Figures 6.7 and 6.8.

- 1. For the given conditions, what is the read access time?
- 2. Suppose the processor is reading a byte \$4D from location \$000FFE. What are the contents of the address bus and data bus and the logic levels of the control signals during the active read bus cycle?
- 3. If three wait states are inserted for writing a word at location \$001000, how many clock cycles is the effective write cycle? When are the wait states inserted?

#### Solution

1. Read access time: The read access time is defined as the time lapse from when the address has become stable to when the data have become valid. From Figure 6.7, it can be observed that this corresponds to the time between the end of S1 and the end of S6; that is, five states, or 2.5 clock cycles. At a 10-MHz clock, each clock cycle is 100 nanoseconds. Thus,

#### read access time = 2.5 clock cycles = 250 nanoseconds

2. Active read-cycle operation: Location \$000FFE is an even address. The even (or upper) byte is selected by the UDS. Reading data \$4D from \$000FFE results in

| Address bus (A23-A1) = \$000FFE;          | AS is low                  |
|-------------------------------------------|----------------------------|
| Data bus (D7–D0) = tristate;              | LDS is high(not selected)  |
| Data bus $(D15-D8) = $4D;$                | UDS is low(selected)       |
| $R/\overline{W}$ (read operation) = high; | DTACK is low(acknowledged) |

3. Wait states during the write operation: The wait states are inserted after state S4. Each wait state corresponds to one clock cycle. The write bus cycle without wait states takes four clock cycles. Thus,

write bus cycle with three wait states corresponds to seven clock cycles.

Wait-state insertion for the read bus cycle is similar to that for the write bus cycle for all members of the 68000 family of processors. It should be remembered that the 68008 processor is a reduced-bus version of the 68000, with a data bus only 8 bits wide.

#### 6.3 MEMORY AND I/O SYSTEM DESIGN CONSIDERATIONS

Any microcomputer system includes RAM (read/write random access memory), ROM (read-only random access memory), and I/O (input/output) systems. RAM and I/O can be selected only during read or write operations. ROM can be selected only during read operations. CS and CE signals are generated in accordance with these constraints.

#### The Memory Subsystem Design

Figure 6.11 illustrates the details of a 64-kilobyte (64K-by-8) memory system. E0 output of the first decoder enables the second decoder. Y0 output of the second decoder drives the chip select (/CS) inputs of the even and odd memory units. These units consist of 32K-by-8 memory devices. /UDS and /LDS further drive the chip enable (/CE) inputs and select the even or odd unit, providing a 64K-by-8 configuration. If both units are selected, the system becomes a 32-kiloword (32K-by-16) memory system.

The 8-state shift register is the memory controller that provides the /DTACK signal to the processor. Initially, all the Q outputs are at a high level (logic 1). The shift register is enabled by the corresponding chip select signal (/Y0 in this case), and starts shifting a logic 0 from Q0 to Q7 at each CX0 clock transition. Depending upon the response time of the memory system, proper Q output is routed as the effective /DTACK input to the processor through the DTACK logic. The shift register returns to the all-1 condition when the enable signal (/Y0 in this case) is removed.

For the 68000 family of processors, the first kilobyte of memory corresponds to the vector table. The first eight locations correspond to the reset vectors, which should be in the ROM space. In most of the 68000-based systems, these eight locations are physical ROM locations. In some systems, additional logic is used to shift the memory



FIGURE 6.11 Memory system and DTACK generation for the 68000.

reference of these eight locations to a ROM device elsewhere in the memory map. The other part of the vector table can be contained in the RAM space. On system power-up, the reset routine initializes the vector table with proper values.

#### Signal Buffering Considerations

Due to electronic loading constraints, signal buffering is used to increase the drive capability of the signals. Transceivers are used to accomplish the buffering, as indicated in Figure 6.12. A **transceiver** is a logic device that can transmit a signal in either direction, depending upon the direction control. The address and the unidirectional control signals are buffered by transceiver bank [1] to go from the processor to the memory or I/O (X to Y). The data bus is buffered by transceiver bank [2], which is controlled by the R/\*Wsignal. For read operations (when the R/\*W signal is at a high level), data flows from the memory or I/O to the processor (Y to X), and vice versa.<sup>8</sup> In this conceptual framework, the memory or I/O system can be expanded to any size.

The following example problem provides a review of memory system design.



#### Example 6.3 Memory system design. Refer to the memory system of Figure 6.11.

- 1. Specify the memory or I/O ranges that can be selected by the  $\overline{E0}$  through  $\overline{E15}$  signals
- 2. The  $\overline{Y14}$  and  $\overline{Y15}$  signals are ANDed to generate an I/O chip select. What is the corresponding I/O range?
- 3. How much delay is there from the time the memory units are selected ( $\overline{Y0}$  becoming active low) until DTACK occurs for the conditions indicated?
- 4. If the transceiver IC is 8 bits wide, how many such ICs are required for transceiver banks [1] and [2] in the system of Figure 6.12?

#### Solution

1. Memory or I/O ranges: The first 4/16 decoder divides the available 16-megabyte address space into 16 equal ranges of 1 megabyte each. Thus, each E output goes low for a 1-megabyte range and selects memory as follows:

> E0 selects range \$000000..\$0FFFFF E1 selects range \$100000..\$1FFFFF

The second 4/16 decoder is activated by the  $\overline{E0}$  output of the first decoder. The second decoder further divides this 1-megabyte range into 16 equal ranges of 64 kilobytes each. Thus, each Y output from the second decoder goes low for a 64-kilobyte range and selects memory as follows:

> Y0 selects range \$000000..\$00FFFF **Y1** selects range \$010000..\$01FFFF **Y15** selects range \$0F0000..\$0FFFFF

- ranges are
  - $\overline{Y}$  = \$0E0000 through \$0EFFFF
- ANDing these two 64-kilobyte ranges would yield a 128-kilobyte I/O chip select range between \$0E0000 and \$0FFFFF.
- 3. Delay for DTACK occurrence: The Q1 output of the shift register goes to active zero two CX0 clock activations after the  $\overline{Y0}$  signal goes active low and selects the

from the first decoder and the  $\overline{Y0}$  through  $\overline{Y15}$  signals from the second decoder.

: E15 selects range \$F00000..\$FFFFFF

2. I/O chip select: From the preceding solution, it can be seen that the  $\overline{Y14}$  and  $\overline{Y15}$ 

 $\overline{Y15}$  = \$0F0000 through \$0FFFFF

memory. CXO is twice the frequency of the CXI processor clock, and two CXO activations correspond to one CXI activation. Ql is routed as the /DTACK input to the processor. Thus, /DTACK occurs one processor clock after the selection. **4. 8-bit transceiver ICs for buffering:** Transceiver bank [1] buffers 27 signals and requires 4 ICs. Transceiver bank [2] buffers 16 signals and requires 2 ICs.

In our discussion thus far, we have emphasized static RAMs, which are composed of flip-flop arrays. Dynamic RAMs, which involve charge storage on a capacitive element and periodic refresh of the charge, are becoming increasingly popular. Dynamic RAM devices are two to four times denser than static RAMs. However, they require complex memory controllers and use interrupts for refresh by the processor. We will discuss dynamic RAM implementation schemes along with the interrupts in subsequent chapters.

As of this writing, 64-kilobyte static memory devices and 256-kilobyte dynamic memory devices are becoming available. Some of these devices have an additional selection control input called the output enable (OE), which is similar to the CS and CE inputs. The I/O interface is essentially similar to the memory interface. Data books may be consulted for design details.<sup>9</sup>

#### 6.4 CONTROL INTERFACE SCHEMES

In addition to the memory and I/O interface, processors have a control interface. The primary hardware signals that control and direct the 68000 microprocessor are RESET, HALT, and BERR (bus error). The DMA and interrupt signals (to be discussed later) also control the processor. In this section, we will first consider the reset and halt interface and follow with a discussion of timing signals and the bus error.

#### Reset and Halt Interface

Figure 6.13 illustrates the reset and halt interface with the 68000 processor. For the values shown, the MC3456 monostable produces a 100-millisecond pulse on the power-up reset. This activates both the /RESET and /HALT inputs to the 68000. On power-up, processors usually require more time to come to a stable state due to electronic and switching transients. The 68000 requires at least a 128-clock-cycle time equivalent to come to a stable state on the power-up condition. The 100-millisecond reset and halt pulses are more than adequate for any 68000 family member. For a reset condition to occur, both the /RESET and /HALT inputs should be activated to a low level.

The processor goes into the supervisor mode on reset. Reset exception processing, which is always the system initialization routine, starts as soon as the /RESET and /HALT are negated (go to high-level). The same sequence of operations occurs for the manual reset. The 74LS00 cross-coupled gates debounce the reset switch, providing clean /RESET and /HALT activation to the processor. Manual activation should last for at





FIGURE 6.13 Reset and halt interface for the 68000. (Courtesy of Motorola, Inc.)

least ten clock cycles. (Refer to Chapter 5 for software details on reset exception pro cessing.)

Of particular interest is the bidirectional property of the RESET line. The processor can execute a software reset instruction in the supervisor mode. The reset line then acts as an output, resetting the other peripherals connected to the 68000. When the processor drives the /RESET line <u>as an output</u>, it goes active low for 124 clock cycles.

When the bidirectional /HALT line is used as an input in conjunction with the /RESET input and is activated by external circuits, the 68000 goes into a system reset condition. On the other hand, if the /HALT input is activated individually, the processor is halted after the completion of the current bus cycle. In the halt state, address and data lines are put in their high-impedance state, and the control lines are negated; however, the DMA control lines are available for bus arbitration. The halt condition of the processor is used for hardware troubleshooting and single-step operation. The processor resumes the halted operation soon after the negation of the /HALT input line.

\_When a double bus fault condition (Chapter 5) is detected, the processor uses the /HALT line as an output and drives it low; this, in turn, halts any devices connected to it.

### Timing Signals Associated with the 68000

The timing signals associated with the 68000 processor are indicated in Figure 6.14. A 32-MHz clock signal is derived from a crystal oscillator circuit. The 8-bit binary counter (divide-by-256) circuit provides the binary signals:



FIGURE 6.14 Bus error and timing signals for the 68000.

The CX0 signal is used for DTACK timing generation (refer to Figure 6.11). The CX1 signal runs the processor at 8 MHz. Signals CX2 through CX7 can be used by any other I/O or memory systems. In the case we are now considering, CX7 is used to drive the bus error control logic. The system clock can be changed to any value that suits the requirements.

The 68000 processor provides an E (enable) clock as an output. The E clock is one-tenth the frequency of processor clock CX1 and is used to drive the 6800 or other synchronous peripherals.

### **Bus Error Considerations**

Of very special importance in all 68000-based systems is the bus error (/BERR) signal. It informs the processor that a bus error has occurred. It originates from a bus error controller, as indicated in Figure 6.14. The bus error controller is usually a watchdog timer; that is, a counter circuit reset to zero at the start of each bus cycle, which counts up at each clock transition. When it reaches its set maximum count, it generates a pulse signifying the time that has lapsed since the start of the last bus cycle.

The 16-state shift register acts as the bus error controller and provides the /BERR signal to the processor. All the <u>B outputs are</u> at a high level initially. The controller is driven by the ANDed output of /UDS and /LDS signals from the processor. When a new bus cycle starts, either /UDS or /LDS, or both, go to a low-active state (logic 0). Thus, the controller is enabled during each bus cycle and shifts a logic 0 from BO to B15 at each CX7 clock transition. Depending upon the maximum allowed response time of the addressed devices, proper B output is routed as the effective /BERR input to the processor through the /BERR logic.

If the /DTACK is given out by the addressed device within the time permitted, the bus cycle is normally terminated and the strobes (/LDS and/or /UDS) go to the inactive logic 1 level. This restores the shift register to the all-1 condition, and the /BERR activation does not occur. Otherwise, logic 0 propagates through the shift register and ultimately reaches the processor as /BERR (through its selected B output). The processor then goes into the bus error condition. Software details of bus error exception processing are discussed in Chapter 5.

On occasion, a particular bus cycle may be faulty and must be rerun. External logic indicates this rerun condition to the 68000 processor by simultaneously activating the /BERR and /HALT inputs. On the occurrence of the rerun condition, the processor aborts the current bus cycle and goes into a halt state. After the /BERR and /HALT inputs are negated (return to a high level), the processor reruns the aborted bus cycle with the same address and data values. This helps the processor to correct any immediate errors due to hardware transients on the lines.

The following example problem provides a review of the control interface to the 68000.

Example 6.4 Control interface to the 68000. The system clock is 32 MHz for the 68000-based systems illustrated in Figures 6.13 and 6.14.

- 1. What is the frequency of the enable output clock E?
- 2. What is the minimum amount of time the manual reset should last?
- 3. The B1 output of the bus error controller is routed as the BERR input to the procesthe strobes have been activated.

sor. How much time would elapse before the BERR input goes to active low after

#### Solution

 Frequency of the E clock: For the conditions given, the processor clock CX1 = 8 MHz. The E clock is one-tenth the frequency of the CX1 clock. Thus,

E clock = CX1/10 = 800 KHz

2. Manual reset timing T: The manual reset should last for at least ten CX1 processor clock periods. Thus,

## $T(reset) = 10 \times 1/8$ MHz = 1.25 microseconds

3. **BERR timing:** For the conditions indicated in Figure 6.14, the CX7 clock drives the bus error controller shift register. The shift register is enabled during a bus cycle, when either LDS or UDS, or both, go low active. It takes two CX7 clockings after the enable to shift a logic 0 to B1 output. B1, in turn, activates the BERR input to the processor if DTACK does not occur.

Since the CX7 clock at 1/8 MHz corresponds to 8 microseconds, two CX7 clock periods correspond to 16 microseconds. Thus, BERR occurs (in the absence of DTACK) 16 microseconds after the strobe activations.

In the preceding example, a delay of up to 120 microseconds can be obtained by routing B15 as the  $\overline{\text{BERR}}$  input to the processor. If more delay is required, additional counter or shift register circuits can be incorporated into the system.

## 6.5 68000-BASED BUSING SCHEMES

In order to support system expansion for the 68000 family of microprocessors, Motorola introduced two busing schemes: the VERSA bus and the VME bus. Both of these widely used busing schemes support 8-, 16-, and 32-bit data transfers and the associated protocols.<sup>10,11</sup>

#### The VERSA Bus

Figure 6.15 illustrates a typical VERSA busing scheme. The hardware interface consists of two edge connectors:

P1: primary connector-140-pin interface; and

P2: secondary connector-120-pin interface.

**Primary Interface P1** The primary interface P1 supports 24 address lines, 16 data lines, and the associated control lines as indicated. The address, data, and control lines of the P1 interface are those of the 68000 processor.

## 68000-BASED VERSA MODULE



#### FIGURE 6.15 VERSA bus P1 and P2 particulars for 68000-based systems.

The asynchronous bus interface consists of the strobes (/AS, /LDS, /UDS, and R/\*W) and the /DTACK. The seven-level priority interrupt interface is the standard 68000 interrupt interface. It consists of the interrupt request signals 1RQ1 through 1RQ7 and the associated interrupt acknowledge signal IACK.

Several of the VERSA modules can be bused together on a VERSA bus backplane. One or more processor modules may be used. All the signals are TTL compatible. Each module presents one unit TTL load on the corresponding input signal line. The bus drivers on each module are of the open collector type and support up to 16-unit TTL loads.

When several VERSA modules are bused together, there should be a bus arbitration scheme. The VERSA bus supports such a scheme using the five bus arbitration request signals BR0-BR4 from the requesting modules to a master controller module. The master controller responds to the requesting modules by sending a bus clear signal (BCLR), if the bus is granted.

The PI interface supports 5,  $\pm 12$ , and  $\pm 15$  DC voltages and an ample number of signal grounds. In addition, there are the numerous fault detection and control lines, in-

#### P1 PRIMARY INTERFACE

24 ADDRESS LINES 16 DATA LINES 5 ASYNCHRONOUS BUS CONTROLS LEVEL 7 PRIORITY INTERRUPT INTERFACE LEVEL 5 ARBITRATION POWER FAULT DETECTION AND CONTROL REDUNDANT AND EXTRA PINS

#### P2 SECONDARY INTERFACE

50 I/O INTERFACE 32-BIT EXPANSION SERIAL COMMUNICATIONS POWER AND GROUND EXTRA PINS eluding /BERR and /HALT. The PI interface is generally sufficient if extended capabilities are not required.

Secondary Interface P2 In order to expand the system to full 32-bit address and 32-bit data, a secondary interface through the edge connector P2 is used, as illustrated in Figure 6.15. This interface also supports 50 I/O lines and serial communications to other systems. Although the VERSA busing scheme is gradually being replaced by the VME busing scheme, there are still many VERSA schemes in the industry that are being expanded on an ongoing basis.



FIGURE 6.16 VME busing scheme and structure. (Courtesy of Motorola, Inc.)

### The VME Bus

Redefinition of VERSA bus with emphasis on international standards has resulted in the VME bus. The VME bus interfaces with the VME modules as shown in Figure 6.16. It is an optimized busing architecture with primary PI and secondary P2 interfaces through the respective edge connectors. Up to 16 modules can be interfaced on the backplane VME bus. These edge connectors are 96 pins each with functional groups as shown in Figure 6.17.

As illustrated in Figures 6.16 and 6.17, the VME busing architecture consists of three buses. The VME backplane bus, contained in the PI interface connector, supports all of the global resources needed fdr the VME modules. The VMS serial communications bus (which is also part of the PI interface) supports the serial communication between two or more VME modules. Similar to the VERSA busing scheme, the PI interface in the VME scheme can handle up to 16-bit data transfers and a seven-level priority interrupt interface.

The VMX bus, which is part of the P2 interface, is a high-speed parallel bus and is local to six adjacent modules. This helps to expand the local subsystem. In most 16-bit applications, the PI interface would be sufficient. However, if the system needs to be expanded to 32 bits, or if additional I/O or VMX capabilities are required, a P2 interface should also be used.

System expansion is very easy with the VERSA or VME busing schemes. It is sufficient to obtain card cages with the VERSA or VME backplanes and populate them with the respective VERSA or VME modules. The photos of Figure 6.18 are of typical VERSA and VME card cages and modules.

consulted for further information, such as bus arbitration methods.

problem.

**Example 6.5** VERSA and VME busing schemes. State which of the two busing schemes, the VERSA or the VME, is preferable in the following circumstances:

1. an A/D and D/A interface is required; 2. multiprocessing with local I/O and memory resources is required;

3. diagnostics are required.

Give reasons for each of your choices.

#### Solution

**1.** A/D and D/A interface: The A/D (analog-to-digital converter) is an I/O device that converts an analog input signal into a corresponding digital word and interfaces with

Detailed specifications are available for both busing schemes. These should be

We will now review the system-level busing schemes by means of an example



FIGURE 6.17 VME bus P1 and P2 interface particulars.

the microprocessor. The D/A (digital-to-analog converter) is another I/O device that accepts a digital word from the microprocessor and converts it into a corresponding analog voltage.

Both the VERSA and VME schemes are useful with P1 and P2 interfaces. The VME scheme, however, shares the 50 connections in P2 between I/O and VMX. If both the 50-pin I/O interface and the VMX capability are required at the same time, the VME is limited. In such situations, the VERSA bus is preferable.

- 2. Multiprocessing with local resources: Clearly, the VME busing scheme is preferable with P1 and P2 interfaces because of well-defined VMX capability for local resource expansion.
- 3. Diagnostics: The VERSA busing scheme is preferable because of its well-defined fault detection and control on the P1 interface, itself.

The VME is one of the most popular busing schemes in the industry. Even though it was developed for the 68000 family of processors, it supports other processor fami-









Intelligent Peripherial controller



1/O Transition



Hardware

FIGURE 6.18 VERSA and VME card cages and modules. (Courtesy Motorola, Inc.)

lies, such as the 8086/80286/80386. Products that are compatible with the VMB bus are available from several vendors.

Other industry standard busing schemes include the Multibus-11 from Intel Corporation and the NU bus from Texas Instruments. The system-level properties of these buses are similar to those of the VME and VERSA buses. The 68000 family of processors can interface with both of these buses with equal ease.

#### 6.6 SUMMARY

In this chapter we described the hardware signals of the 68000 processor and their properties. We also introduced the hardware interface schemes for the 68000.

Memory and I/O interface schemes are very important. The read/write random access memory (RAM) is particularly suitable for the storage and retrieval of programs and data. The static RAMs store information in flip-Hop arrays. Static RAMs are the systems of choice in high-reliability applications. Dynamic RAM (DRAM) devices store information on a single MOS transistor memory cell and are denser than static RAMs. DRAM-based systems are preferable in applications requiring high density.

ROMs and EPROMs are of the read-only type and are nonvolatile. They are particularly well suited for storing permanent programs and data elements.

We also studied details of the asynchronous memory and I/O interface, as well as read and write bus-cycle timings. A bus cycle is normally terminated when the addressed memory or I/O responds to the processor with /DTACK. The processor introduces wait states until either /DTACK or /BERR occurs. The occurrence of /BERR signifies a bus error. The processor responds by going into exception processing.

On considering the important system control interface schemes relating to /RESET, /HALT, and /BERR, we saw that simultaneous activation of both /RESET and /HALT results in a system reset condition. Activation of /HALT alone results in a processor halt condition. Simultaneous activation of both /HALT and /BERR results in a bus-cycle rerun condition. Activation of /BERR alone results in a bus error condition. The processor uses the reset pin as an output when executing the /RESET instruction. Similarly, the processor uses the halt pin as an output when there is a double bus fault condition.

We ended the chapter with a discussion of the VERSA and VME busing schemes and interfaces. The VERSA scheme is more flexible, while the VME scheme is more efficient and universal. Other industry standard buses, such as the Multibus-11 from Intel and the NU bus from Texas Instruments, are similar to the VME and VERSA buses.

#### PROBLEMS

- 6.1 In byte-organized memory, can the /LDS and /UDS signals be gated together to form a single chip select? Why or why not?
- 6.2 Specify the conditions of the address and the data buses in the following circumstances:

(a)  $\overline{AS}$  is inactive,  $R/\overline{W}$  is low;

(b)  $\overline{AS}$  and  $\overline{UDS}$  are active,  $\overline{LDS}$  is inactive,  $R/\overline{W}$  is high; (c) an external HALT signal is received by the processor.

- 6.3 What are the primary differences between the RAM, ROM, and backup memory, such as a disk?
  - (a) Can the EPROM be used where the system stack is to be located? Why or why not?
  - (b) Can the normal RAM be used where the reset vectors are located? Why or why not?(c) Is it possible to use battery backup RAM in place of a disk-type backup memory?
    - Why or why not?
- 6.4 In the memory system of Figure 6.6, the LDS and UDS signals have been interchanged. Specify the effect on
  - (a) the memory read operation of the byte, word, and long-word operands;
  - (b) the memory write operation.
- 6.5 Under the conditions given in Problem 6.4, specify how the following operands will be written into the memory:

(a) MOVE.L D0,\$1000 D0 = \$3456789A
 (b) MOVEP.L D0,\$2000 D0 = \$A9876543

6.6 Refer to the memory system with the timing waveform given in Figures 6.7 and 6.8.

(a) What are the read and write access times if the processor clock CX1 is 4 MHz?
(b) Repeat (a) with 8- and 12-MHz CX1 frequencies.
(c) Repeat (a) and (b) on the condition of four wait states.

6.7 The 68000 processor performs read-modify/write (RMW) operations while executing instructions such as TAS. Draw the RMW waveform while the processor is performing TAS at

(a) location \$7000;

- (b) location \$700A.
- 6.8 For the memory system of Figure 6.11, what are the chip select (CS) ranges for

(a) the  $\overline{E0}$  through  $\overline{E15}$  outputs from the first decoder;

- (b) the  $\overline{Y0}$  through  $\overline{Y15}$  outputs from the second decoder.
- 6.9 Design the hardware to generate chip selects to access 4K blocks of memory words as shown.



**6.10** In a memory system interface to the 68000 microprocessor, the slow memory has a response time of 250 nanoseconds and the fast memory has a response time of 62.5

nanoseconds. The processor CX1 clock is 8 MHz. A 16-MHz CX0 clock signal is also available.

Design a memory controller interface to generate DTACK to the processor.

- 6.11 Repeat Problem 6.10 to interface memory and I/O with the following requirements:
  - (a) a response time of 750 nanoseconds;
  - (b) a response time of 15 microseconds.
- 6.12 Obtaining the information from data sheets, design the system shown in Figure 6.11 with real parts.
- 6.13 Redesign the memory system of Problem 6.12 with high-density parts, such as the 64K-by-8 and 128K-by-8 devices. The RAM should occupy the memory map starting at location \$2000.
- 6.14 Using the 64K-by-8 RAM and EPROM/ROM devices, design a memory system for the 68000 microprocessor with the following memory map (word organized):

| \$000000 to \$007FFE | RAM or EPROM |
|----------------------|--------------|
| \$008000 to \$00BFFE | RAM          |
| \$00C000 to \$00FFFE | EPROM/ROM    |
| \$010000 to \$01FFFE | I/O space    |

- 6.15 It is necessary to protect the supervisor memory from being accessed in the user mode. Describe a scheme to accomplish this while generating chip select logic. (*Hint:* The function code signal FC2 has to be used in the logic.)
- 6.16 Specify the relative advantages and disadvantages of using the address, data, and control buffering of Figure 6.12.
- 6.17 Write software to test the memory in the \$020000-to-\$021FFE range.
- 6.18 Design a hardware or software method to test the I/O interface connected to the 68000 microprocessor, occupying a range between \$010000 and \$01FFFE. (*Hint:* In the 68000, I/O and memory look similar.)
- 6.19 Draw the waveforms of the CX0 through CX7 signals in Figure 6.14, given that the system clock is 32 MHz.
- 6.20 Specify all possible valid conditions of the combination of RESET, HALT, and BERR inputs to the processor. (*Note:* some combinations may be invalid.)
- 6.21 What would happen if the RESET input stayed active low all the time? Is there a possible remedy?
- 6.22 State two distinct conditions in which the 68000 uses its
  - (a) <u>RESET</u> output;
    (b) <u>HALT</u> output.

6.23 For an 8-MHz 68000 system, what is the minimum time required for the power-up RESET condition? Why? Describe what happens in the following situations:

| •    | condition: http://www.                                                                                           |                    |
|------|------------------------------------------------------------------------------------------------------------------|--------------------|
|      | (a) the <b>RESET</b> input stays active                                                                          |                    |
|      | (b) the RESET stays active for tw                                                                                |                    |
| 6.24 | With regard to the VERSA and V                                                                                   | ME busing schemes, |
|      | and the second second second second second second second second second second second second second second second | ana ana 7          |

(a) which occupies more physical space?(b) which is more flexible?

(c) which is more cost effective?

(d) which is more efficient?

- 6.25 Is it possible to interface VERSA modules onto the VME bus? If so, indicate how this can be accomplished.
- 6,26 Show how the interrupt levels can be increased on

(a) the VERSA busing scheme;

(b) the VME busing scheme.

6.27 Obtaining the information from appropriate data sheets, show how a system can be expanded using VERSA modules.

6.28 Repeat Problem 6.27 using VME modules.

#### **ENDNOTES**

- 1. Motorola, Inc. MC68000 Data Book. Phoenix, AZ: Motorola Technical Operations, 1983.
- 2. Motorola, Inc. MC68008 Data Book. Phoenix, AZ: Motorola Technical Operations, 1983.
- 3. Motorola, Inc. MTT8: 68000 Course Notes. Phoenix, AZ: Motorola Technical Operations, 1987.
- 4. Stranes, T. "Design Philosophy Behind the M68000." Byte (Apr., May, Jun. 1983).
- Miller, M.A. "68000 Program Applications and Bus Cycle Timing." Chap. 4 in The 68000 Microprocessor: Architecture, Programming, and Applications. Columbus, OH: Merrill, 1988.
- Harman, T., and Lawson, B. The Motorola MC68000 Microprocessor. Englewood Cliffs, NJ: Prentice-Hall, 1985.
- 7. Motorola, Inc. MC68000 16/32-Bit Microprocessor Programmer's Reference Manual, Fifth Edition. Englewood Cliffs, NJ: Prentice-Hall, 1987.
- 8. Texas Instruments, Inc. TTL and CMOS Data Books. Houston, TX: Texas Instruments, 1988.
- 9. Toshiba America, Inc. MOS Memory Products Data Book. Tustin, CA: Toshiba, 1988.
- 10. Balph, T., and Black, J. "Applications of VERSAbus Modules." *Electronic Design* (Mar. 1982).
- 11. Motorola, Inc. The VME Bus Specification. Temple, AZ: Motorola Microsystems, 1987.

# CHAPTER

# The 68000 Parallel **Interface and Applications**

#### Objectives

In this chapter we will study:

Architecture of the 6821 PIA and 68230 Pl/T devices Interfacing the PIA and PI/T I/O applications using the 68000/6821 PIA Data entry and display applications Electromechanical applications

#### 7.0 INTRODUCTION

Any microprocessor communicates with the external I/O (input/output) through either a parallel or a serial interface. In this chapter, we will concentrate on the parallel interface. There are several devices that support either a synchronous or asynchronous parallel interface with the 68000 family of processors. The most widely used are the 6821 PIA for the synchronous interface and the **68230 PI/T** for the asynchronous interface.<sup>1/2</sup> Study of the material in this chapter will provide the foundation for using the parallel interface in practical applications.

## 7.1 SYNCHRONOUS PARALLEL INTERFACE WITH THE 68000

The earlier 6800 family of peripheral devices are of the synchronous type. These devices can be interfaced easily with the 68000 family of processors by means of the synchronous bus (/E, /VMA, /VPA signals).<sup>3</sup>

### 6821 PIA (Peripheral Interface Adapter) Architecture

The 6821 PIA is one of the most widely used 8-bit parallel interface devices. It is contained in a 40-pin NMOS DIP device. The structure of the PIA is indicated in Figure 7.1. It consists of two 8-bit parallel ports A and B and associated control signals CA1, CA2, CB1, and CB2. Each port consists of three internal registers:

- 1. ORA and ORB (output registers A and B);
- 2. DDRA and DDRB (data direction registers A and B); and
- 3. CRA and CRB (control registers A and B).



FIGURE 7.1 The 6821 PIA architecture and interface to the 68000.



The DDR and OR in each port occupy the same address. The control register determines the individual access.

Output and Data Direction Registers The output registers (ORA and ORB) interface with the external I/O devices and systems and are capable of driving a unit TTL load. Each bit of these ports is individually programmable to be either an input or an output. The data direction registers (DDRA and DDRB) determine the direction of the output register bit. If there is a 0 in the DDR bit position, the corresponding bit is an input. If there is a 1 in the DDR bit position, the corresponding bit is an output. For example, if 07 (b7 b6 b5 b4 b3 b2 bl bO = 00000111) is written into DDRA, then PA7 through PA3 are configured as inputs and PA2 through PA0 are configured as outputs.

Control Registers CRA and CRB Control register CRA determines the nature of the control lines CA1 and CA2. Figure 7.2 illustrates the typical structure of CRA. Depending upon the application, an appropriate control word can be written into CRA to configure CA1, CA2, and IRQ A (interrupt request port A). The CRB format is similar to that of CRA; it configures CB1, CB2, and IRQB (interrupt request port B) lines. Bit 2 is very important in CRA and CRB. When it is 0, the data direction register is selected. When it is 1, the output register is selected.



#### 6821 PIA Synchronous Interface with the 68000

The PIA is an 8-bit device and occupies either the lower 8 bits or the upper 8 bits of the data bus. To the processor, it resembles four memory locations (ORA/DDRA, CRA, ORB/DDRB, and CRB).<sup>4</sup>

Figure 7.1 illustrates the synchronous interface of the 6821 PIA-1 with the 68000 microprocessor. The decoded address bus, along with the /AS and /VMA signals, generates the chip selects for the PIA. PIA is connected to the lower data bus D0-D7; accordingly, /LDS is used to enable PIA-1. The A2 and Al address lines drive the PIA register select inputs RSI and RS0 and select either ORA/DDRA, CRA, ORB/DDRB, or CRB (for 00, 01, 10, 11 conditions on RSI and RS0).

Interface logic senses the chip select signals and generates the VPA signal to the processor. VPA signifies a successful bus cycle and data transfer. The E clock initiates the data transfers and concludes the bus cycle. Interface with any synchronous peripherals is similar to the PIA interface.

#### I/O Interface and Design Applications

form generation.

### Example 7.1 6821 PIA-1 I/O application: waveform generation.

interface of Figure 7.1, develop:

- 1. the necessary hardware

#### Solution

- crease drive capability.
- be used in the rest of the software.

Between lines 15 and 18, all the pins of port A and port B are configured as outputs by writing \$FF into the corresponding data direction registers (DDRs). At lines 21 and 22, \$04 is written into CRA and CRB, which changes b2 in these control registers to 1 and provides access to the output registers instead of the DDRs.

At lines 23 and 24, the byte contents of DO and Dl are output to ports A and B, respectively. At line 25, the delay routine is called. At lines 26 and 27, DO is incremented by \$03 and Dl is rotated one position left. These operations provide the next binary words to be output to ports A and B. At line 28, the BRA instruction loops the program back to line 23.

The delay routine between lines 31 and 34 produces a software delay, the value of which depends on the initial contents of D3. This delay is the amount of time during which the output port values remain the same.

One of the most important requirements of a digital system is the capacity for generating timing waveforms to accomplish various tasks at different intervals. With a microcomputer, such waveforms can be easily generated with great flexibility.

The following example problem deals with the initialization of the PIA in wave-

In an industrial application, it is necessary to generate an 8-bit binary word, the value of which changes as \$01, \$02, \$04, ..., \$08, and another 8-bit binary word, the value of which changes in increments of three (\$00, \$03, \$06, . . .). Using the 68000/PIA-l

2. the software to accomplish this task. The base address of PIAis at \$020021.

1. Hardware: The hardware of Figure 7.1 is self-contained. To obtain two 8-bit binary words, both ports must be configured as outputs. Output drivers may be used to in-

2. Software: Figure 7.3 indicates the 68000 operating assembly listings to accomplish the given task. Between lines 5 and 10, all the PIA registers are declared. Lines 11 and 12 initialize the DO and DI registers to \$00000000 and \$01. These registers will

|   | LINE              | ADD        | R                                   |              |                       |                         |                                                                        |
|---|-------------------|------------|-------------------------------------|--------------|-----------------------|-------------------------|------------------------------------------------------------------------|
|   |                   | 1<br>1     |                                     |              |                       |                         | ;PIA ctr 2/14/89<br>;initialize PIA<br>OPT A                           |
|   |                   | 34         |                                     |              |                       |                         | 0RG \$1200<br>DRG \$120021                                             |
|   |                   | б          | 15002000<br>15002000<br>15002000    |              |                       |                         | CRA EQU \$020021                                                       |
|   |                   | 8          | 00020025                            |              |                       |                         | DDRB EQU \$020025<br>ORB EQU \$020025                                  |
|   |                   | 10         | 00020027<br>0001200                 | 4280         |                       |                         | CRB EQU \$020027<br>CRB EQU \$020027<br>START CLR.L DO<br>MOVE.B 01,D1 |
|   |                   | 1, I       | 00001202                            | 1538         | 0001                  |                         | ;get access to DDRA & DDRB<br>set up Ports A & B as outputs            |
|   |                   | 1,4<br>1,5 | 00001206                            | 13FC<br>0023 | 0000                  | 5000                    | MOVE.B #\$UU,CRA                                                       |
| ļ |                   |            | 0000120E                            | 13FC<br>0027 |                       |                         |                                                                        |
|   |                   |            | 00001516                            | 1500         |                       |                         |                                                                        |
|   |                   |            | 0000151E                            | 13FC<br>0025 | OOFF                  | UUUZ                    | ;get access to ORA & ORB                                               |
|   |                   | 19<br>20   |                                     | 1.380        | 0004                  | 5000                    | ;and output data                                                       |
| Ì |                   |            | 0000155E                            | 0023         |                       |                         |                                                                        |
|   |                   |            | 00001.236                           | 0027<br>1300 | 0002                  | 0057                    | L LOOP MOVE.B DO, ORA                                                  |
|   |                   | pq         | 0001230<br>0001246<br>0001246       | 9 6188       | I                     | UUCS                    | BSR.S DELAY<br>ADDO.W #\$03,D0                                         |
|   |                   | 23         | 00001244<br>00001244<br>00001248    | , E31°       |                       |                         | ROL.B #\$D1,D1<br>BRA.S LOOP                                           |
|   |                   | 29<br>21   | 4 00003241<br>r                     | A 4E71       | 5                     |                         | NOP<br>;delay subroutine                                               |
|   |                   | 3:         | 1 00001240<br>9 00001250            | 0 5343       | 3                     | ]                       | DELAY MOVE.W #\$0100,D3<br>AGAIN SUBQ.W #\$01,D3<br>BNE.S AGAIN        |
|   |                   | Э-         | 3 0000125<br>4 0000125<br>4 0000125 | 4 4E?!       | 5                     |                         | RTS<br>END                                                             |
|   |                   | SSE        | MBLER ERR                           | ORS =        | 0                     |                         | SYMBOL TABLE                                                           |
|   | AGA<br>DDR<br>ORB | -          | 00001250<br>00020025<br>00020025    | DELA         | 000<br>Y 000<br>T 000 | 20023<br>0124C<br>01200 | C FOOD 0000153P OKY OUGEDOED                                           |

FIGURE 7.3 The 68000 listings for timing-signal generation with PIA.

It is possible to interface another PIA to the upper part of data bus. The control registers can be appropriately configured in a manner similar to that described in Example 7.1 to effectively use the control signals. We will deal with interfacing the second PIA in another example which follows.

Example 7.2 Interfacing a second PIA. In the control system application described in Example 7.1, it is now necessary to interface a second PIA, PIA-2, onto the upper part of the data bus.

- 1. Describe how this can be accomplished.
- 2. What is the memory map of PIA-2 given the conditions described?
- 3. It is required that a low-to-high transition be recognized on CA1 to enable the interthat will accomplish this task.

#### Solution

1. PIA-2 interface: The PIA-2 interface is similar to the PIA-1 interface of Figure 7.1, with the following modifications:

#### PIA-2

Connect D0-D7 data li CHIP ENABLE Other control, address, chip selects

2. Memory map of PIA-2: PIA-2 occupies the upper (or even) byte locations compared to PIA-1. Thus, the base address of PIA-2 is at \$020020. The memory map of PIA-2 is as follows:

CRA CRB

3. Control word in CRA of PIA-2 for CA1 and CA2 control: Using the CRA format of Figure 7.2, it can be seen that writing a control word

> b7 b6 b5 b4 b3 b2 b1 b0  $0 \ 0 \ 1 \ 0 \ 1 \ 1 \ 1 \ 1 \ = \$2F$

into CRA of PIA-2 defines CA2 as a pulse output, recognizes the CA1 low-to-high transition from the I/O, and activates the IRQA interrupt line to the 68000.

rupt and generate a positive pulse on CA2 for PIA-2. Explain the sequence of events

#### 68000

| ines | to D8-D15 data lines |
|------|----------------------|
|      | to UDS               |
| and  | same as PIA-1        |

**ORA/DDRA** at \$020020 at \$020022 ORB/DDRB at \$020024 at \$020026



Consider port A of PIA-2 to be configured as input. In response to the CA1 transition and corresponding interrupt, the 68000 will access and read port A of PIA-2. Whenever the I/O port is accessed, a CA2 positive pulse, equal to the duration of one E clock, will be generated. The I/O device recognizes this pulse on CA2 and moves to the next I/O operation.5

The I/O device generates a low-to-high transition on CA1 when the next I/O data are available on port A. I/O operation becomes repetitive. The pulse-mode operation is equally valid when the port is configured as an output and the processor is writing data to the I/O device.

### 7.2 THE 68230 PARALLEL INTERFACE AND TIMER (PI/T)

Figure 7.4 illustrates the pin configuration and general architecture of the 68230 PI/T device. It is contained in a 48-pin DIP package and is fabricated with HMOS technology. The 68230 PI/T consists of two bidirectional 8-bit ports A and B and a multipurpose 8bit port C. The bits are individually programmable to be either inputs or outputs for all three ports. In addition, there is a 4-bit H port for handshake operations. The HI and H2 lines are associated with port A. The H3 and H4 lines are associated with port B. Port C can be configured to handle the interrupts and the DMA functions.

#### Registers and I/O Ports

The 68230 PI/T consists of 23 active 8-bit registers as shown in Figure 7.5. Information written into the appropriate registers by the 68000 processor controls the 68230 operation. Some of the PI/T registers are read-only and contain the status information pfthe I/O operations. The 68000 processor reads this information and performs the appropriate I/O functions as defined by the software. The 68230 PI/T device is very complex; however, we will present some of the basic features. For further detail, data sheets should be consulted.

Port Control Registers (PGCR, PACR, PBCR) The modes of operation of ports A and B and port H (handshake) are controlled by the control words written into the port general control register (PGCR) and the port A/B control registers (PACR/PBCR). These control registers are illustrated in Figure 7.6.

Data Direction Registers (PADDR, PBDDR, PCDDR) The direction of each bit in the port is determined by the contents of these registers. If there is a 1 in a bit position, the corresponding port bit is an output; if there is a 0, the corresponding port bit is an input. For example,

#### 11110000

written into PADDR configures the lower four bits of port A as inputs and the upper four bits as outputs.

| Number*    | Symbol | Name                        | Function                         |
|------------|--------|-----------------------------|----------------------------------|
| 1          | PGCR   | Port General Control Reg.   | Controls port modes              |
| 3          | PSRR   | Port Service Request Reg.   | Controls service routines        |
| 5          | PADDR  | Port A Data Direction Reg.  | Controls direction PA            |
| 7          | PBDDR  | Port B Data Direction Reg.  | Controls direction PB            |
| 9          | PCDDR  | Port C Data Direction Reg.  | Controls direction PC            |
| В          | PIVR   | Port Interrupt Vector Reg.  | Contains interrupt vector        |
| D          | PACR   | Port A Control Reg.         | Controls H1/H2                   |
| F          | PBCR   | Port B Control Reg.         | Controls H3/H4                   |
| 11         | PADR   | Port A Data Reg.            | Contains I/O data PA             |
| 13         | PBDR   | Port B Data Reg.            | Contains I/O data PB             |
| 15         | PAAR   | Port A Alternate Data Reg.  | Contains instant PA              |
| 17         | PBAR   | Port B Alternate Data Reg.  | Contains instant PB              |
| 19         | PCDR   | Port C Data Reg.            | Contains I/O data PC             |
| 1 <b>B</b> | PSR    | Port Status Reg.            | Contains status H1-H4            |
| 1D         | i —    |                             | Not used                         |
| IF         | _      | —                           | Not used                         |
| 21         | TCR    | Timer Control Reg.          | Controls timer modes             |
| 23         | TIVR   | Timer Interrupt Vector Reg. | Contains timer vector            |
| 25         | ĺ      |                             |                                  |
| 27         | CPRH   | Counter Preload Reg. High   |                                  |
| 29         | CPRM   | Counter Preload Reg. Med.   | Contains 24-bit preloaded number |
| 2 <b>B</b> | CPRL   | Counter Preload Reg. Low    |                                  |
| 2D         | _      |                             |                                  |
| 2F         | CNTRH  | Counter Reg. High           |                                  |
| 31         | CNTRM  | Counter Reg. Med.           | Acts as a 24-bit counter         |
| 33         | CNTRL  | Counter Reg. Low            |                                  |
| 35         | TSR    | Timer Status Reg.           | Contains status of counters      |
| 37         |        |                             | Not used                         |
| 39         | _      |                             | Not used                         |
| 3B         | _      | -                           | Not used                         |
| 3D         |        |                             | Not used                         |
| 3F         |        | _                           | Not used                         |

\*Relative address increment with respect to the base address.

FIGURE 7.5 The 68230 PI/T register structure.

Data Registers (PADR, PBDR, PCDR) These registers contain the latched I/O data. Input data is latched during a read operation and output data is latched during a write operation. When the alternate data registers are used, however, I/O data is not latched, and is instantaneous.

Other Registers (PSRR, PSR, PIVR, TIVR) The PSRR controls the service requests of the interrupts, DMA, and the signal lines H1-H4. The PSR contains the status

FIGURE 7.6 (a) The PGCR control register and (b) the PACR control format.



16 bits;

8 bits;

Bidirectional 16 bits



00:Submode 0

of the handshake port H. The PIVR and TIVR contain the 8-bit address for the interrupt vectors to be used by the processor. The other counter/timer-related registers are for timing applications.

### Interfacing the 68230 Pi/T

Figure 7.7 diagrams the required connections between the 68000 and the 68230. The 68230 PI/T is driven by the 68000 processor clock. The decoded address bus, gated



 $\overline{Y1}$  active low for \$010000 . . \$01FFFF.

FIGURE 7.7 Interfacing the 68230 PI/T and the 68000.

with  $\overline{\text{LDS}}$ , generates the chip select  $\overline{\text{CS}}$  signal to the 68230. The lower address lines A5-A1 drive the register select input lines RS5-RS1 to select one of the 23 active registers from the register bank.<sup>6</sup>

The PI/T data lines D7-D0 are connected to the lower byte of the data bus D7-D0, since the 68230 is selected via  $\overline{\text{LDS}}$ . The R/W and  $\overline{\text{RESET}}$  signals from the processor directly drive the corresponding inputs of the PI/T. The multifunction port signals PC3, PC5, PC6, and PC7 are interfaced with the 68000 through the interrupt control logic as indicated. PC0, PC1, PC2, and PC4 are available for any other I/O interface. Ports A, B, and H are used for the I/O interface.

We will now review the concepts introduced thus far with the help of an example problem.

Example 7.3 The 68230 PI/T interface. Consider the interface diagrammed in Figure 7.7.

- 1. What is the address range for the 68230?
- 2. Where are PGCR, PADDR, and PBDDR located?
- registers.

#### Solution

address boundary as shown:

Redundant ---

shown (primary):

Redundant locations are also possible.

need not be initialized.

3. Suppose it is necessary to program port A as an 8-bit output port and port B as output on lines PB7-PB2 and input on lines PB1 and PB0. Configure the appropriate

1. Address range: The  $\overline{Y1}$  output of the address decoder network is active low for the address range \$010000 to \$01FFFF. (Refer to Section 6.3 of Chapter 6.) It is further gated with the A6 and  $\overline{\text{LDS}}$  signals. The  $\overline{\text{CS}}$  signal is generated when  $\overline{\text{Y1}}$ ,  $\overline{\text{LDS}}$ , and A6 are all at a low level. There is a redundant memory map for the 68230 on the odd

```
Primary → $010001 to $01003F
              $010081 to $0100BF
               $010101 to $01013F
                       :
                       :
                       :
```

2. Locations of PGCR, PADDR, and PBDDR: Following the given address range and Figure 7.5, all the registers are sequentially mapped at odd byte locations as

> PGCR located at 010001 PADDR located at 010005 PBDDR located at 010007

3. A and B ports (refer to Figure 7.6): Both ports are used in the unidirectional 8-bit mode (mode 0). As such, PGCR, PADDR, and PBDDR should be initialized as indicated in the diagram that follows. The H port is not used, and PACR and PBCR



In the preceding example, because of the selection of the 68230 due to the /LDS signal, the registers are mapped at consecutive odd byte locations. By changing /LDS to /UDS and connecting the data bus of the 68230 to the upper byte of the 68000 data bus (D8-D15), the 68230 can be easily mapped at consecutive even bytes. To make full use of the 16-bit data bus of the 68000, one PI/T device is interfaced with the lower byte and a second PI/T is interfaced with the upper byte of the data bus.

#### 7.3 DATA ENTRY AND DISPLAY SYSTEMS

In any computer system, data entry and data display are of utmost importance. A simple data entry mechanism may be a switch or a keyboard. A complex data entry mechanism may involve sophisticated sensors. In either case, the processor reads an input port and interprets and validates the entered data.

Similarly, a simple data display may be a light-emitting diode (LED). Complex data display may involve sophisticated graphics on a terminal. In either case, the processor sends the processed data to an output display port.

#### The Keyboard and Hex Display Interface

As illustrated in Figure 7.8, the keyboard/display interface to the 68000 through the 68230 PI/T combines data entry and display concepts. The keyboard encoder (74C922) activates one of the X columns and scans the Y rows to detect if any key has been pressed. When a key is pressed, the 74C922 encodes the X and Y data to corresponding binary data on its ABCD outputs. In addition, a data-valid signal is generated on its DV output whenever a valid key is pressed.

#### System Hardware and Software Considerations

Hardware The encoded ABCD signals and the DV signal from the encoder are interfaced to port B. Two 7-segment display devices are interfaced to port A. These devices (7300 series) have internal decoders and drivers and display the pressed key in hex format. For this application, port A is configured as an output port and port B as an input port.

FIGURE 7.8 Keyboard/display interface with the 68000 through the 68230 PI/T. (Courtesy of Aldo Aden and Ignacio Martinez: FIU.)



7300 displays with internal drivers

Software Figure 7.9 is the system flowchart. The assembled listings for the keyboard/ display interface are indicated in Figure 7.10.

Between lines 15 and 21 in the listings, the initializations are accomplished. The 68230 is configured to operate in mode 0 by loading 00 into the PGCR. Port B is configured as input and port A as output by loading 00 and FF into the respective data direction registers PBDDR and PADDR.

The main routine between lines 23 and 36 calls the keycode subroutine to obtain valid key code. It then sends the valid key code to port A to be displayed. The main routine also calls the **check subroutine** to check whether any new key has been pressed. This is necessary to ensure that the same key is not being recognized all the time. When a second key is pressed, the main routine shifts the old key code to the MSD position,



All capacitors are in microfarads.



| 2; ADBN/MAR1                | /DISPLAY II<br>PINEZ/SUBBA<br>D DISPLAYS | RAO 7/86   | F.I<br>Y CC    |
|-----------------------------|------------------------------------------|------------|----------------|
| 5'<br>6<br>7<br>8; 68230 Pi | דיי פענדגיינ                             | DC DESTNE  | LL<br>OP<br>OR |
| 9 00010001                  | PGCR                                     | EOU        | נ<br>\$0       |
| 10 00010005                 |                                          | EQU        | \$0            |
|                             | PBDDR                                    | ĒQU        | \$0            |
| 12 00010011                 | PADR                                     | EQU        | \$0            |
| 13 00010013                 | PBDR                                     | EQU        | \$Ŭ            |
| 14 00002000                 | STKP                                     | EQU        | \$0            |
|                             | IZE REGIST                               |            | [/T ]          |
| 16 00001000                 |                                          | OCO1 INIT  | C MO           |
|                             | 0001                                     | ~~~        |                |
| 17 00001008                 | 13FC 0000                                | 0001       | MO             |
| 1. 00001010                 | 0007<br>13FC 00FF                        | 0001       | MO             |
| 18 00001010                 | 13FC OOFF<br>0005                        | 0001       | no             |
| 19 00001018                 |                                          | 0011       | MO             |
| 50 0000101E                 | 287C 0001                                |            | MÕ             |
| 21 00001024                 | 2E7C 0000                                |            | MO             |
| 22;KEY PROCI                |                                          |            |                |
| 45010000 ES                 | 4280                                     | MAIN       |                |
| 24 0000102C                 | 4281                                     |            | CL             |
| 25 0000102E                 | 6116                                     | AGAIN      | I BS           |
| 56 00001030                 | 1688                                     |            | MO             |
| 25 00001035                 | 4E71                                     |            | NO             |
| 28 00001034                 | 1200                                     |            | MO             |
| 29 00001036                 | 6120                                     |            | BS             |
| 30 00001038                 | 610C                                     |            | BS             |
| 31 0000103A<br>32 0000103C  | E909<br>D001                             |            | LS<br>AD       |
| 33 0000103C                 | 1680                                     |            | MO             |
| 34 00001040                 | 6116                                     |            | BS             |
| 35 00001042                 | 60E6                                     |            | BR             |
| 36 00001044                 | 4E71                                     |            | NO             |
| 37;KEY CODE                 | ROUTINE:RI                               | EADS PB: C |                |
| 38 00001046                 | 1014                                     | KEYCODE    |                |
| 39 00001048                 | 0800 0004                                |            | вт             |
| 40 0000104C                 | 67F8                                     |            | BE             |
| 41 0000104E                 | 0500 000£                                |            | AN             |
| 42 00001056                 | 4675                                     |            | RT.            |
| 43;CHECK ROU                |                                          |            |                |
|                             | 1014                                     | CHECK      |                |
| 45 000010SA                 |                                          |            | BT.            |
| 46 0000105₽<br>47 00001064  | 66F8<br>4875                             |            | BN)<br>RT      |
| 48 00001066                 | -112                                     |            | EN:            |
|                             |                                          |            | 1.14           |
|                             |                                          |            |                |

FIGURE 7.10 The 68230/68000-based keyboard/display system listings.

```
. U
ODE
LEN
      108
PΤ
       А
      $1000
RG
J10001 ;GENERAL CONTROL REG
D10005 ;PA DATA DIR REG
10007 PB DATA DIR REG
10011 PA DATA REG
10013 ;PB DATA REG
DO2000 ;STACK POINTER VALUE
PORTS
OVE.B #$00,PGCR;MODE0
OVE.B #$DO,PBDDR; PB INPUT
OVE.B #$FF,PADDR;PA OUTPUT
DVEA.L #PADR, A3; A3 REFERS PADR
OVEA.L #PBDR,A4;A4 REFERS PBDR
OVEA.L #STKP,A7;STACK DEFINED
ROUTINE:
LR.L DU;CLEAR DU
LR.L DL ;CLEAR DL
SR.S KEY CODE
OVE.B DO,(AB) ; TO DISPLAY
VE.B DO,D1
               ;SAVE OLD KEY
      CHECK
               SAME KEY CHECK
SR.S
SR.S
      KEYCODE ;GET KEY CODE
               OLD KEY TO MSD
SL.B
      #4,D1
               TWO KEY CODE
DD.B
      D1,DO
VE.B DD, (AB) ;DOUBLE DISPLAY
               SAME KEY CHECK
SR.S
      CHECK
      MAIN
A.S
AINS KEY CODE AS LOW NIBBLE IN DO
OVE.B (A4),DO;READ KEY
     #4,D0 ;DATA VALID ?
KEY CODE
rst
3Q.S
ID.B #$OF,DD
Y AND LOOPS UNTIL NEW KEY
VE.B (A4),DO;READ KEY
ST
      #4,DO
NE CHECK
rs.
ND
```

puts the new code in the LSD position, and displays it (lines 31 to 33). The program then goes back into the main loop.

The **keycode routine** between lines 38 and 42 reads port B and loops until the data-valid signal is high (signifying that a key has been activated). It then puts the valid key code in the lower nibble of the DO register and returns to the main routine.

The **check routine** between lines 44 and 47 checks whether the same data-valid signal is present, signifying that the same key has been kept pressed.

The following example problem provides a review of the keyboard/display interface with the 68000/68230 system.

**Example 7.4** Keyboard/display interface with 68000/68230 system. Consider the hardware and software of Figures 7.8, 7.9, and 7.10.

1. What happens when the same key is kept pressed continuously?

2. The keys are pressed in sequence as follows:

12345

Indicate how the keys are displayed.

### Solution

- Same key: It will be displayed in the LSD position. The program goes into an indefinite check loop and will not recognize any other key. This concept is known as key lockout.
- 2. Key display: After two key entries, the MSD is cleared to the 0 condition. The display is as follows:

|               | MSD | LSD |
|---------------|-----|-----|
| after 1st key | 0   | 1   |
| after 2nd key | 1   | 2   |
| after 3rd key | 0   | 3   |
| after 4th key | 3   | 4   |
| after 5th key | 0   | 5   |

The preceding example sheds light on the initialization of the appropriate registers of the 68230 PI/T. In I/O applications, it is usually necessary to analyze the existing software and predict the results, as we have done in the second part of the problem.

The keyboard and segment displays may be replaced by other data entry and display mechanisms. The concepts we have discussed remain valid. Modifications, such as software switch debouncing, can be accomplished by checking the key code for sameness with a delay in between.

### Other Forms of Keyboard and Interface Schemes

The hex keyboard we have examined is of limited scope. The computer and other keyboards have up to 128 key positions. A 128-position keyboard can be wired as a 16-by-8 XY matrix; however, the key positions can be conveniently located. Figure 7.11 shows a conceptual 128-position keyboard interface with the 68000 through the 68230 PI/T port B.

FIGURE 7.11 Conceptual 128-key position keyboard interface to the 68000.



The processor activates one line of the 16-column input lines (X0-X15) through a 4/16 decoder connected to lines PB0 through PB3 of the PI/T. It then senses one line of the eight-row output lines (Y0-Y7) through an 8/1 multiplexer driven by the lines PB4 through PB6 of the PI/T. The Z output of the multiplexer is connected to the PB7 line. When a key is pressed, the Z output goes active for a unique combination of the digital word on lines PB0 through PB6. This essentially generates a 7-bit binary code for the 128-position keyboard.

In the case described, only port B of the PI/T is used. PB0 through PB6 must be configured as outputs and PB7 as input. The software generates a sequential 7-bit word on lines PB6 through PB0. When a key is pressed, the PB7 input is activated. The processor senses this condition and matches the 7-bit code on lines PB6 through PB0 to the

pressed key. Additional software can process this binary information to generate other key codes, such as ASCII. The concept can be extended to any s.ze key matrix.

In order to display one of the 128 keys, more sophisticated display units, such as the terminal or alphanumeric type, are required.

### 7.4 ELECTROMECHANICAL APPLICATIONS

Many industrial applications depend on position control, which can be accomplished with the help of **stepper motors**. Stepper motors can be controlled by microprocessors for flexibility and accuracy. In this section, we will describe a 68000-dnven electrome-chanical position control system using the stepper motor.



### **Rotational and Linear Stepper Motors**

In Figure 7.12, we see some typical stepper motors. They are available in the range of 0.9 to 7.5 degrees per step. Each stepper motor has four windings: W0, W1, W2, and W3. When the code on these windings changes in a given sequence, the stepper rotates one step either clockwise or counterclockwise, as indicated in Figure 7.13. Linear steppers have an internal gear mechanism to convert rotational motion into linear motion.

| Counter-  | W Code (hex) | W3 | W2 | WI | wo | Function                                     |
|-----------|--------------|----|----|----|----|----------------------------------------------|
| clockwise | 0 F          | 1  | 1  | 1  | 1  | Standby                                      |
|           | 03           | 0  | 0  | 1  | 1  | First CW code                                |
|           | 09           | 1  | 0  | 0  | 1  | Move one step                                |
|           | 0 C          | 1  | 1  | 0  | 0  | Move one step                                |
|           | 06           | 0  | 1  | 1  | 0  | First CCW code                               |
|           | 0 F          | 1  | 1  | 1  | 1  | Standby                                      |
| Clockwi   | ise          |    |    |    |    | s the stepper coil.<br>tes the stepper coil. |



### **Stepper-Motor Interface Considerations**

**Hardware** Figure 7.14 shows interface of a 7.5-degree resolution stepper motor with the 68000/68230 PI/T system. The four windings (W0-W3) are connected to port A of the 68230 PI/T through optoisolators and high-current drivers, as shown. **Optoisolators** prevent the inductive transients from the motor windings from feeding back into the microcomputer module. The sensor inputs on port B provide an S control word for the stepper movement. The format of the S control word is as follows:



b7 = 0 Clockwise 1 Counterclockwise



FIGURE 7.14 Typical interface of the stepper motor and the 68000/68230 PI/T system. (Courtesy of J. Wongchang, J. Launez, and F. Chorlett, FIU).

If the stepper code does not change, the stepper will not rotate and stays in the same position. When the code is changed, there is some delay before the stepper responds. A delay of 10 to 100 milliseconds is typical.

*Software* The operating listings for the preceding stepper-motor system are given in Figure 7.15. Between lines 5 and 21, the required PI/T registers are declared and initialized. The 68230 PI/T is set up for mode 0 operation, with handshake lines disabled. Port A is configured as an output port and port B as an input port. The D2 and D3 registers are loaded with the first stepper code words for the clockwise and counterclockwise routines, as depicted in Figure 7.13.

|   | 1.<br>2                    | ;step                         | ADDR<br>oper                    | 2/89                 |               |               |                      |
|---|----------------------------|-------------------------------|---------------------------------|----------------------|---------------|---------------|----------------------|
|   | 3<br>4<br>5<br>6<br>7<br>8 | dec];<br>0001<br>0001<br>0001 | lare<br>10001<br>10005<br>10007 |                      | regi          | sters         | P(<br>P)<br>P)<br>P) |
|   | 9<br>10                    | 0001                          | .0013<br>.001D                  |                      |               |               | P1<br>P2             |
|   | 11                         |                               | 001F                            |                      |               |               | PI                   |
|   | 12<br>13                   | ;init<br>0000                 | 1ali<br>1200                    | 13FC                 | rt A<br>0000  | outpu<br>0001 | t & Po<br>INIT       |
|   | 14                         | 0000                          | 1208                            | 0001<br>13FC<br>001D | 0000          | 0001          |                      |
|   | 1,5                        | 0000                          | 1210                            |                      | 0000          | 0001          |                      |
|   | 16                         | 0000                          | 17578                           | 13FC<br>0007         | 0000          | 0001          |                      |
|   | 17                         | 0000                          | 1550                            | 13FC<br>0005         | OOFF          | 0001          |                      |
|   | 18                         | ;init                         | iali                            | zest                 | epper         | code:         | s                    |
|   | 19                         | 0000                          | 1559                            | 143C                 | 0033          |               |                      |
|   | 20                         |                               | 755C                            | 163C                 | 0066          |               |                      |
|   | 21<br>22                   | 0000<br>read;                 | 1230<br>v f                     |                      |               | rot c         | ha -+-               |
| I | 23                         | ,read<br>0000                 | .Xf:<br>1234                    | rom Pl<br>1039       | B and<br>DOO1 |               | te ste<br>READ       |
| I | 24                         | 0000                          |                                 | 6708                 | 3663          | 1011          | мпар                 |
| I | 25                         |                               | 153C                            |                      |               |               |                      |
| ļ | 26                         |                               | 123E                            | 640C                 |               |               |                      |
|   | 27<br>28                   |                               | 1240<br>1242                    | 651A<br>60F0         |               |               |                      |
| ĺ |                            | 0000                          |                                 |                      | 0001          | 0011          | NULL                 |
| I | 30                         | 0000                          | 124A                            | 60E8                 |               |               |                      |
| I | 31                         | 0000                          |                                 | 1303                 | 0001          | 0011          | CW                   |
|   | 32<br>33                   |                               | 1252<br>1254                    | 6118<br>6218         |               |               |                      |
|   | 34                         |                               | 1256                            | 5500                 |               |               |                      |
|   | 35                         |                               | 1528                            | 6615                 |               |               |                      |
|   | 3E                         |                               | 125A                            | 6DD8                 |               |               | • •                  |
|   | 37<br>38                   |                               |                                 | 13C3<br>6108         | 0001          | 0011          | CCW                  |
|   | PE                         | 0000                          |                                 | E318                 |               |               |                      |
| ļ | 40                         | 0000                          | 1566                            | 5500                 |               |               |                      |
|   | 41                         | 0000                          |                                 | 66F2                 |               |               |                      |
|   | 42<br>43                   | 0000<br>0000                  |                                 | 60C8<br>283C         | 0000          | 6188          | DT V                 |
|   | 44                         | 0000                          |                                 | 4271                 | 5000          |               | IGAIN                |
|   | 45                         | 0000                          | 1274                            | D485                 | 0000          |               |                      |
| ŀ | 46<br>47                   | 0000<br>0000                  |                                 | 66F6                 |               |               |                      |
|   | 47                         | 0000                          | ne.ic                           | 4875                 |               |               |                      |
| _ |                            |                               |                                 |                      |               |               |                      |

FIGURE 7.15 The 68000 assembly listings for the stepper-motor interface.

OPT A ORG \$1200 GCR EQU \$010001 ADDR EQU \$010005 PBDDR EQU \$010007 PADR EQU \$010011 BDR EQU \$010013 ΕQŪ PACR \$01001D BCR EQU \$01001F Port B input MOVE.B #\$00,PGCR MOVE.B #\$00,PACR MOVE.B #\$00,PBCR MOVE.B #\$00,PBDDR MOVE.B #\$FF,PADDR MOVE.B #\$33,D2 ;cw code MOVE.B #\$66,D3 ;ccw code MOVE.B #\$FF,D4 epper accordingly MOVE.B PBDR,DO BEQ.S ;null routine NULL LSL.B #1,DO BCC.S CW ;clockwise routine ;counterclockwise BCS.S CCW BRA.S READ MOVE.B D4,PADR BRA.S READ MOVE.B D2,PADR DLY ;delay routine #1,D2 BSR.S ROR.B SUBQ.B #2,DO BNE.S CW BRA.S READ MOVE.B D3, PADR BSR.S DLY ;delay routine ROL.B #1,D3 SUBQ.B #2,D0 BNE.S CCW READ BRA.S MOVE.L #25000,D5 NOP SUBIL #01,D5 BNE.S AGAIN RTS

The **READ module** between lines 23 and 28 reads the S control word, checks it, and branches to the appropriate routines. The **NULL module** at lines 29 and 30 outputs the null code to the stepper and branches back to the READ module.

The **CW module** between lines 31 and 36 outputs the clockwise code to the stepper, calls the **DLY subroutine** for the stepper-response delay, and generates the next clockwise sequential code (ROR.B #1,D2 instruction). It then goes into the CW loop until the DO register (which contains information about bits b6 through bO of the S control word) is decremented to zero. In effect, this amounts to rotating the stepper in the clockwise direction, as specified by the S control word. Finally, the CW module branches back to the READ module.

The **CCW module** between lines 37 and 42 is similar to the CW module. It rotates the stepper in the counterclockwise direction as specified by the S control word. It also branches back to the READ module.

The **DLY module** between lines 43 and 47 generates the delay required for the stepper motor to respond.

We will now review the stepper-motor interface by means of an example problem.

### Example 7.5 The stepper-motor interface.

Consider the stepper-motor interface described in Figures 7.13, 7.14, and 7.15.

- 1. Explain in detail how the CCW module works.
- 2. Assume an 8-MHz processor clock. Compute the approximate delay value for the DLY routine.
- 3. The S control word is OF = 0.00011111. How many times will the stepper rotate and in which direction?

### Solution

1. The CCW module: This module is contained between lines 37 and 42 of Figure 7.15. The software details are as follows:

| CCW | MOVE.B         | D3, PADR     |   | output counterclockwise code to stepper.                                     |
|-----|----------------|--------------|---|------------------------------------------------------------------------------|
|     | BSR.S<br>ROL.B | DLY<br>#1,D3 | ; | call the delay routine.<br>generate next CCW code in<br>the upward sequence. |
|     | SUBQ.B         | #2,DO        | ; | subtract 2 from DO. DO<br>contains left shifted S<br>control word.           |
|     | BNE.S          | CCW          | ; | branch back to CCW until<br>DO is decremented to                             |
|     | BRA.S          | READ         | ; | zero.<br>branch back to READ<br>module.                                      |

2. DLY routine timing Td: The T(R/W) values for the instructions in the DLY routine are as follows (refer to Section 3.5 of Chapter 3):

|       |                  | 1(10(11)                        |        |
|-------|------------------|---------------------------------|--------|
| DLY   | MOVE.L #25000,D5 | 12(3/0)                         |        |
| AGAIN | NOP              | 4(1/0)                          |        |
|       | SUBI.L #01,D5    | 16(3/0)                         | T = 30 |
|       | BNE.S - AGAIN    | 16(3/0)<br>10(2/0) branch taken |        |
|       |                  | 8(1/0) branch not tak           | en     |

T(R/W)

The AGAIN loop is run 25,000 times. Each time it takes 30 T-states, as shown. At 8 MHz, each T-state corresponds to 125 nanoseconds. Thus, the approximate delay time is as follows:

### $Td = 25,000 \times 30 \times 125$ nanoseconds = 93.75 milliseconds

3. Stepper rotation: For the S control word:

 $\$0F = 0\ 0\ 0\ 0\ 1\ 1\ 1\ 1$ 

The rotation is clockwise, since b7 = 0. The stepper rotates 15 times.

In the preceding example, we have introduced the very practical modular software approach. It involves writing independent software modules with local parameters and using them in conjunction with each other to generate system-level software activity.

### **Position Control Systems**

Several stepper motors can be connected to a microcomputer, with each stepper controlling one axis. For example, an XY plotter system could have three steppers: X, Y, and Z. The X and Y steppers would control the X- and Y-axis motions and the Z stepper would control the Z-axis pen motion. Such a system is illustrated in Figure 7.16. Port A of PI/T-1 drives the X and Y steppers. Ports B and C of PI/T-1 accept the control words from the X and Y steppers. Port A of PI/T-2 drives the Z stepper and port B of PI/T-2 accepts the control word from the Z stepper.

The software involves reading each control word and moving the corresponding stepper accordingly. Software for each stepper is similar to that presented in Figure 7.15. Care should be taken to avoid control of one stepper affecting control of another.

A robotic system is a more complex position control system in which as many as ten stepper motors control individual movements. A parallel printer interface involves controlling three or more stepper motors. The system interface and the software, however, are similar to those we have described.<sup>9</sup>



### 7.5 SUMMARY

In this chapter we introduced the parallel I/O interface with the 68000 processor. Two of the most popular and widely used devices are the 6821 PI A and the 68230 PI/T.

The 6821 PI A (peripheral interface adapter) is a synchronous 8-bit parallel interface device, belonging to the earlier 6800 microprocessor. It has two individually programmable 8-bit I/O ports, A and B, along with the associated control signals. The PIA contains six internal registers and occupies four bytes of memory space. The processor communicates with the external I/O with the help of these registers.

The 68230 PI/T (parallel interface and timer) is an asynchronous parallel interface device belonging to the 68000 family of processors. It has three individually programmable 8-bit I/O ports, A, B, and C. In addition, it has a 4-bit handshake control, port H. The PI/T contains 23 active 8-bit internal registers and occupies 23 bytes of memory space. The PI/T communicates with the external I/O with the help of these registers.

The 68000 family of processors uses memory-mapped I/O in which the I/O interface is similar to the memory interface. The PI A/68000 interface uses the synchronous bus. In the case of the PI/T, the asynchronous bus is used.

In the waveform-generation I/O application (Example 7.1), we described the interface of the 68000 and 6821 PIA and the PIA initialization schemes. Waveform generation can be extended to generate any required timing sequence for digital words.

In our discussion of data entry and display systems, we described the interface of external I/O units, such as keyboards and segment displays, to the 68000/68230 PI/T systems. Keys can be electrically wired as an XY matrix. The processor generates a digital word and drives the interface logic for the matrix-type keyboard. The processor then senses the key closure through the interface logic and generates the appropriate key code for the closed key using software routines.

The stepper-motor interface to the 68000/68230 PI/T system emphasizes electromechanical position control applications. Any complex position control system can be easily implemented by means of stepper motors and microcomputer control. A threestepper system can control XY plotters and a pen-motion mechanism. A robotic system is a more complex position control system in which up to ten stepper motors control individual movements.

### PROBLEMS

- 7.1 Using the 68000/6821 PIA interface, develop a waveform-generator system in which (a) port A resembles an 8-bit up counter and port B an 8-bit down counter; (b) modification of the software results in a 16-bit shift register type system.
- and PIA-2 base address at \$020020.

registers (a) in the primary address range; (b) in the redundant address range.

- 7.4 Redesign the I/O system of Figure 7.7 so that the 68230 is contained between \$010001 and \$010003F, without any redundancy.
- 7.5 Configure and write proper words into the appropriate PJ/T registers so that (a) PA7 through PA3 are outputs and PA2 through PA0 are inputs, (b) PB7 through PB0 are bidirectional, and (c) handshake lines are not used.
- 7.6 Configure and write proper words into the appropriate PI/T registers so that (a) ports PA and PB are 16-bit bidirectional, (b) port H is low active, and (c) the H interrupts are disabled.
- 7.7 Redesign the I/O system of Figure 7.7 interfacing two 68230 PI/T devices. The memory map indicates PI/T-1 base address at \$010000 on an even byte boundary; PI/T-2 base address at \$010001 on an odd byte boundary.
- Given the conditions of Problem 7.7, describe the memory map of both 68230 devices in 7.8 detail.
- State whether the system of Figure 7.7 will function properly under the following 7.9 conditions:

(a)  $\overline{LDS}$  and  $\overline{UDS}$  are interchanged. (b)  $\overline{LDS}$  is inactive all the time.

Briefly explain your answers.

the following tasks:

(a) Drive 32 individual relay coils by the 68230 ports. (b) Drive 16 individual relay coils and read in a 16-bit I/O control word.

7.2 Describe the details of the 68000/6821 PIA interface with PIA-1 base address at \$020021

7.3 For the I/O system of Figure 7.7, specify the address locations of all of the 68230 PI/T

7.10 Design an I/O system with two 68230 PI/T devices and conceptualize how to accomplish

- 7.11 Repeat Problem 7.10, with the system driving all 32 relay coils, but also accepting 32-bit control information on the same ports. (*Hint:* External multiplexers may be required.)
- 7.12 With information from the data sheets, fully explain the operation of the keyboard and the 74C922 interface with the 68000/68230 system.
- 7.13 Redesign the keyboard/display interface system to allow for an extended display to 4 hex digits. Port C may be used to drive the extra display digits.

Write the software to achieve the display shift. (The old digit is to be shifted to the MSD position and the newest digit is to be displayed in the LSD position.)

7.14 Analyzing the software of Figure 7.10,

(a) specify the condition of the display at the time of power-up;

- (b) at the beginning of the program;
- (c) when the program is running in the loop and the system reset is activated.
- 7.15 The following keys have been activated in sequence:

### 1324576809

Using the software of Figure 7.10, show how they are displayed in pairs.

7.16 Modify the software of Figure 7.10 so that

(a) before any key is pressed, 00 will be displayed;

(b) before any key is preused, a flashing FF will be displayed.

- 7.17 With reference to the software of Figure 7.10, what will be displayed if two keys are pressed simultaneously? What is this condition called?
- 7.18 Design the hardware and software for the ASCII keyboard interface indicated below. You may use the system video monitor to display the typed characters.



- 7.19 For the system of Problem 7.18, develop software that will result in key lockout.
- **7.20** Repeat Problem 7.19 so that key rollover will occur (that is, keys will be identified in the order of the scanning sequence of the keyboard).
- **7.21** With reference to Example 7.5, design a stepper-motor controller system in which the stepper completes the clockwise rotation of 360 degrees, reverses to perform the counterclockwise rotation, and so on.

(a) In intervals of 100 milliseconds per step.

- (b) In intervals of one second per step.
- **7.22** Redesign the stepper-control system of Example 7.5 so that each time the stepper is activated it goes through
  - (a) a 30-degree rotation;
  - (b) a 60-degree rotation.

7.23 Design a solar tracking system according to Figure 7.17. Stepper 1, containing optical sensors, rotates between 0 and 180 degrees in 24 steps and identifies the maximum intensity position. Stepper 2, containing the solar plates, then rotates to the maximum intensity position. The solar stepper position should be changed once every ten minutes. Also develop the software for this system.



7.24 Repeat Problem 7.23 so that the solar stepper position

(a) is updated every minute;

- (b) is updated continuously.
- (Hint: The sensor stepper has to scan all 24 positions before moving the solar stepper.)
- 7.25 A conveyor-belt system is illustrated in Figure 7.18. The S input controls both steppers, as shown in the accompanying table. Consider 7.5-degree steppers. Slow movement corresponds to 24 steps per minute. Fast movement corresponds to 96 steps per minute. Design the system with hardware and software.
- 7.26 In the preceding problem, the S3 input is a safety input. Design a safety system in which power will shut down and an alarm will sound if S3 is active high for more than a minute on a continuous basis.





BELT CONTROL

### 68000/68230 SYSTEM

STEPPER-2

STILL

CW SLOW

CW FAST

CCW SLOW

STILL

STILL

STILL STILL

|                    | 82                         | S1                              | <b>S</b> 0                           | STEPPER-1                                                                   |  |
|--------------------|----------------------------|---------------------------------|--------------------------------------|-----------------------------------------------------------------------------|--|
| S CONTROL<br>TABLE | 0<br>0<br>0<br>1<br>1<br>1 | 0<br>0<br>1<br>1<br>0<br>0<br>1 | 0<br>1<br>0<br>1<br>0<br>1<br>0<br>1 | STILL<br>STILL<br>STILL<br>STILL<br>CW SLOW<br>CW FAST<br>CCW SLOW<br>STILL |  |

## CHAPTER

### ENDNOTES

- 1. Motorola, Inc. "Data Sheets on 6821 PIA." In *Microcomputer Components Data Book*. Phoenix, AZ: Motorola Technical Operations, 1986.
- 2. Motorola, Inc. 68230 PI/T Data Book. Phoenix, AZ: Motorola Technical Operations, 1986.
- 3. Motorola, Inc. MC68000 Data Book. Phoenix, AZ: Motorola Technical Operations, 1983.
- 4. Miller, M.A. "Parallel Interfacing the 68000." Chap. 5 in The 68000 Microprocessor: Architecture, Programming, and Applications. Columbus, OH: Merrill, 1988.
- 5. Subbarao, W. Microprocessors: Hardware, Software, and Design Applications. Englewood Cliffs, NJ: Prentice-Hall, 1984.
- 6. Andrews, M. Self-Guided Tour through the 68000. Englewood Cliffs, NJ: Prentice-Hall, 1984.
- 7. Airpax, Inc. Data Book on Stepper Motors. Cheshire, CT: Airpax, 1988.
- 8. Fu, K.; Gonzalez, R; and Lee, C. "Introduction." Chap. 1 in Robotics: Control, Sensing, Vision, and Intelligence. New York: McGraw-Hill, 1987.
- Scherer, V., and Peterson, W. The MC68230 PI/T Provides an Effective Interface. App. Note #854. Austin, TX: Motorola Microprocessor Group, 1982.

# The 68000 Serial Interface and Applications

### Objectives

In this chapter we will study:

Principles of serial data communication Architecture of the 6850 ACIA and interface with the 68000 Implementation of the RS-232 serial interface Architecture of the 68901 MFP and interface with the 68000 System applications using the serial interface.

### 8.0 INTRODUCTION

Slower I/O systems, such as keyboards, terminals, modems, and other electromechanical units, usually communicate with fast processors through a serial interface. This reduces the number of external connections to the processor interface.<sup>1</sup>

Of the several serial interface and communication devices, the 6850 asynchronous communications interface adapter (AC1A) and the 68901 multifunction peripheral (MFP) are widely used with 68000-based systems. The **6850 ACIA** belongs to the earlier 6800 family and has standard RS-232 interface properties. The **68901 MFP** is a 68000-family serial interface device and has additional ports and interrupt processing logic associated with it.

Study of the material in this chapter will provide background knowledge of serial data communication concepts. It will also help the reader develop practical applications using the serial interface.

### 8.1 SERIAL DATA COMMUNICATION CONCEPTS

The information sending station is called the **transmitter** and the information receiving station is called the **receiver**. In serial communications, data travels between the transmitter and the receiver serially on a single line, one bit at a time. The **American Standard Code for Information Interchange (ASCII)**, as shown in Figure 8.1, is the most widely used 7-bit code for serial data communications.<sup>2</sup>

|     | MSD  | 0<br>000 | 1<br>001 | 2<br>010 | 3<br>011 | 4<br>100 | 5<br>101     | 6<br>110 | 7<br>111 |
|-----|------|----------|----------|----------|----------|----------|--------------|----------|----------|
| LSD |      |          |          | 010      |          | 100      |              |          |          |
| 0   | 0000 | NUL      | DLE      | SP       | 0        | @        | Р            | ,        | р        |
| 1   | 0001 | SOH      | DC1      | ļ        | 1        | Α        | Q            | а        | ą        |
| 2   | 0010 | STX      | DC2      | "        | 2        | В        | R            | b        | r        |
| 3   | 0011 | ETX      | DC3      | #        | 3        | С        | S            | с        | 5        |
| 4   | 0100 | EOT      | DC4      | \$       | 4        | D        | Т            | d        | t        |
| 5   | 0101 | ENQ      | NAK      | %        | 5        | E        | U            | e        | u        |
| 6   | 0110 | ACK      | SYN      | &        | 6        | F        | V            | f        | v        |
| 7   | 0111 | BEL      | ETB      | •        | 7        | G        | W            | g        | w        |
| 8   | 1000 | BS       | CAN      | (        | 8        | Н        | Х            | h        | х        |
| 9   | 1001 | НТ       | EM       | )        | 9        | I        | Y            | i        | у        |
| Α   | 1010 | LF       | SUB      | *        | :        | Ţ        | Z            | j        | Z        |
| В   | 1011 | VT       | ESC      | +        | ;        | K        | í            | k        | {        |
| С   | 1100 | FF       | FS       | ,        | <        | L        | ١.           |          | ļ        |
| D   | 1101 | CR       | GS       | _        | =        | М        | ]            | m        | }        |
| Ε   | 1110 | so       | RS       |          | >        | N        | 1            | n        | ~        |
| F   | 1113 | SI       | VS       | 1        | ?        | 0        | <del>«</del> | 0        | DEL      |

### FIGURE 8.1 ASCII codes used in microcomputer systems.

Figure 8.2 illustrates a typical asynchronous serial data frame. The **start bit** signifies the beginning of the serial data frame. The next seven bits (b6-b0) represent the ASCII-coded data element. The next bit is the **parity bit**, which is used for error checking. If even parity is used, the total number of Is in the data frame should be an even number, including the parity bit. If odd parity is used, the total number of Is in the data frame should be an odd number. If the parity does not check out at the receiving end, the data frame is in error and will be rejected. The last bits are the **stop bits**, signifying the end of the data frame. There may be one or two stop bits per serial frame.

### FIGURE 8.2 Typical serial data b5 b4 b3 b2 b1 -b0 frame using ASCII code. 0 ł 0 0 0 1 1 1 1 1 7-bit data element Stop Parity bit Direction of data transmission

The rate of data transmission is specified in bits per second and is known as the **baud rate**. The transmitter and the receiver are adjusted to the same baud rate. The receiver recovers the data element from the received serial data frame.

The following example problem will further clarify basic serial data communication concepts.

### *Example 8.1 Serial data communications.* Refer to Figures 8.1 and 8.2.

- Refer to Figures 6.1 and 6.2.
- 1. Specify what ASCII character is being transmitted.
- 2. What is the type of parity, even or odd?
- 3. If the data transmission rate is 300 baud, how many ASCII characters can be transmitted per second on a continuous basis?

### Solution

1. ASCII character: The data element contained in b6-b0 is

$$1011001 = $59$$

which corresponds to ASCII character Y.

- 2. Parity: Including the start and parity bits, the total number of 1s in the data frame is equal to 4, which is an even number. Thus, the data frame has even parity.
- 3. Characters per second: Each serial frame, composed of the start, data, parity, and stop bits, is 11 bits long and represents one character. At 300 baud, the number of frames per second = 300/11 = 27.2. Thus, 27 characters per second can be transmitted.

A baud rate of 300 is relatively slow, but is standard for such electromechanical equipment as keyboards and terminals. With electronic high-speed serial devices, such as modems, higher rates of up to 9600 baud are quite common. Other codes, such as the

8-bit Extended Binary Coded Decimal Interchange Code (EBCDIC), are also very popular. In any event, the basic concepts of the serial data communication remain the same.<sup>3</sup>

### 8.2 6850 ACIA GENERAL ARCHITECTURE

The ACIA is a 24-pin DIP device fabricated with NMOS technology. It is one of the industry standard serial communication devices. In Figure 8.3, the pin configuration and internal architecture of the 6850 ACIA are diagrammed.<sup>4,5</sup>

### **Registers and I/O Ports**

As shown in Figure 8.3(b), the ACIA consists of four registers:

the control register (CR); the status register (SR); the transmit data register (TDR); and the receive data register (RDR).

The **control register** (**CR**) is a write-only register and is written by the processor to configure the ACIA mode of operation.

The **status register** (**SR**) is a read-only register and is at the same address space as the CR. It contains the status of the events associated with the ACIA. The processor reads and interprets the status information and performs the appropriate operations.

The **transmit data register (TDR)** is a write-only register. The processor writes the 8-bit word to be transmitted into this TDR. The parity and control units in the ACIA insert proper parity, start, and stop bits to the data element and generate a complete serial frame. The transmit control logic in the ACIA shifts this frame serially on the **transmit data (TXD) line.** 

The **receive data register** (**RDR**) is a read-only register and is at the same address space as the TDR. It receives the serial data on the **receive data** (**RXD**) **input line** and converts it into an 8-bit parallel word. The parity and control units within the ACIA check and separate the parity, start, and stop bits. The processor reads this 8-bit data in the RDR when it is ready. Any parity error information is sent to the status register.

The **ready-to-send (RTS)** and **clear-to-send (CTS) lines** are handshake signals between the ACIA and the I/O units. The **data carrier detect (DCD) signal** is an input to the ACIA and signifies that the transmission carrier is in progress. The **register select (RS) line** is used to select between the CR/SR and the TDR/RDR pairs.

The **receive clock (RXCLK)** and the **transmit clock (TXCLK)** are the shift clock inputs. They are conditioned by the internal clock generator logic for appropriate receive and transmit baud rates.



FIGURE 8.3 (a) The 6850 ACIA pin diagram and (b) architecture.

### Modes of Operation and Status Conditions of the ACIA

The contents of the control register, as shown in Figure 8.4(a), control the modes of operation of the 6850. The ACIA can activate the interrupt line IRQ, on occ<u>urrence</u> of such events as filling of the RDR, emptying of the TDR, and activation of the CTS. The interrupts can be enabled or disabled by bit 7. RTS output can be configured to be active

### (b)



FIGURE 8.4 (a) The 6850 ACIA control register (CR) format and (b) status register format.

high or low, and the associated interrupt activation can be enabled or disabled by bits 6 and 5. Data formatting can be accomplished by bits 4, 3, and 2. The reset and the clock functions are controlled by bits 1 and 0.

The status register illustrated in Figure 8.4(b) contains status information on the 6850 signals and events. If the interrupt has occurred, b7 is set. Bits 6, 5, and 4 are set for parity, overrun, and frame errors, respectively. A parity error occurs when an even parity is detected instead of an expected odd parity, or vice versa. An overrun error occurs when new data is shifted into the RDR, destroying the old data before it is read by the processor. A frame error occurs when the stop bits are not detected as expected at the end of the frame.

Bit 3 specifies the activity on the /CTS line. Bit 2 is set if the data carrier is absent. Bit 1 is set if the TDR is empty. Bit 0 is set if the RDR is full. The processor reads these status conditions and responds accordingly. Reading or writing into the corresponding registers clears the flag conditions in the SR. The following example problem will clarify the internal architecture of the ACIA.

### Example 8.2 6850 ACIA architecture. In a data transmission application, 6850 is at address space \$010041 for CR/SR and at \$010043 for TDR/RDR.

- 1. Specify the conditions under which each of the registers are addressed.
- ing transmitted or received.

### Solution

further selects the individual registers as indicated;

### **Addressed Location**

010041

010043

### 2. Control word \$45 [refer to Figure 8.4]:



2. Control word \$45 is written into the control register CR. Specify the data format be-

1. Register map (refer to Figure 8.3): Register select input RS is used to select the CR/SR pair (when RS = 0) or the TDR/RDR pair (when RS = 1). The R/W signal

| RS | R/W | <b>Register Selected</b> |
|----|-----|--------------------------|
| 0  | 0   | CR (Write only)          |
|    | 1   | SR (Read only)           |
| 1  | 0   | TDR (Write only)         |
|    | 1   | RDR (Read only)          |

| b4                                    | b3 | b2 | ઝા        | <b>b</b> 0 |
|---------------------------------------|----|----|-----------|------------|
| 0                                     | 0  | 1  | 0         | I          |
| 7-bit odd-parity<br>word; 2 stop bits |    |    | Div<br>by |            |

The data transmission and receiving is configured for a 7-bit odd-parity word with two stop bits. RXCLK and TXCLK are divided by 16 for the proper baud rate. RTS is active high and the interrupt is disabled.

The contents of the control register and the associated modes of operation can be changed under program control. Thus, it is possible to transmit and receive data in a variety of formats and at different baud rates.

## 8.3 THE 6850 ACIA INTERFACE WITH THE 68000 AND APPLICATIONS

The 6850 ACIA belongs to the earlier 6800 family and requires a synchronous bus interface to the processor. The 68000/6850 ACIA interface is similar to the 68000/6821 PIA interface described in Chapter 7.

### 68000/6850 Interface Considerations

In serial data communications, the intelligent unit is known as the DTE (data terminal equipment.) The I/O unit that is communicating with the DTE is known as the DCE (data communication equipment). Figure 8.5 illustrates the DTE/DCE interface. The 68000/6850 system is the DTE. The I/O system (a terminal or printer, for example) is the DCE. The DTE and the DCE communicate on a standard RS-232 serial link.<sup>6</sup>



FIGURE 8.5 The DTE/DCE interface in serial data communications.

In Figure 8.6, the system of Figure 8.5 is detailed. The ACIA requires a synchronous clocking signal for data transfers. This signal is provided by the E clock of the 68000 processor. The address decoder provides an active low  $\overline{Y1}$  select signal for the address range \$010000 to \$01FFFF (refer to Section 6.3 of Chapter 6). It is further gated by the  $\overline{VMA}$  (valid memory address) signal from the processor and generates the



FIGURE 8.6 The 68000/6850 DTE, RS-232, and DCE functional interface.

CS0 chip select for the ACIA. The A6 address line activates the CS1 chip select. The  $\overline{\text{LDS}}$  signal activates the  $\overline{\text{CS2}}$  chip select. The A1 address line drives the register select (RS) input. The other control connections are as shown. The ACIA can be put on the upper byte of the data bus by using the  $\overline{\text{UDS}}$  signal in place of the  $\overline{\text{LDS}}$ .<sup>7</sup>

For the connections shown in Figure 8.6, the 6850 occupies the following memory map, at the odd byte boundary: \$010041 for CR/SR (control register/status register); \$010043 for TDR/RDR (transmit register/receive register).

The MC14411 baud/frequency generator IC accepts a 1.8432-MHz crystal input and generates several clock rates. For our illustration, we have chosen a 4800-Hz signal for the activation of the TXCLK and RXCLK inputs.

For better noise immunity, RS-232 lines are driven by enhanced logic voltage swings. Noise immunity is achieved by the MC1488-type TTL-to-RS-232 converter and driver device. This device is powered by higher voltages ( $V_{DD} = +12$  volts;  $V_{EE} = -12$  volts). It converts TTL levels to RS-232 levels. RS-232 levels follow negative logic convention. Negative voltage in excess of -3 volts is regarded as logic 1; positive voltage in excess of +3 volts is regarded as logic 0. Thus, there is a minimum 6-volt swing on the RS-232 lines. This provides sufficient noise immunity for the RS-232 interface.

On the receiving end, signals coming from the RS-232 lines are converted to TTL levels by the MC1489-type RS-232-to-TTL converter. The double logic inversion caused by the MC1488 and 1489 converters does not cause any system logic mismatch and is totally transparent to the user.

### **RS-232** Interface Application

For most of the standard RS-232 interface applications, approximately four connections are used, as shown in Figure 8.6. The TXD and RXD lines are the serial transmit and receive data lines. The RTS output of the ACIA is gated as the /DTR (data-terminal-ready) signal to the RS-232 interface. The /CTS (clear-to-send) signal from the RS-232 is gated as the /CTS input to the ACIA. The /DCD (data-carrier-detect) input to the 6850 is connected to ground and is always activated.

When the DTE (68000/6850) is in the receive mode, it expects the DCE to activate the /CTS line, signifying that the serial data are coming on the RXD line. The processor polls the SR of the ACIA for any error conditions and for /CTS activity. If there are no errors, and if the /CTS is active, the processor polls to see if the RDR is full. A full RDR implies that the incoming serial data have already been converted into the parallel byte form and are available in the RDR. The processor reads the RDR and accepts the incoming data.

During the transmit mode, the processor polls to see whether the TDR is empty. If it is empty, the processor writes the data byte (to be transmitted serially) into the TDR. During this write operation, the RTS <u>line is</u> activated and is communicated to the DCE as the /DTR. The DCE checks for the DTR active condition and goes into its routine to accept the transmitted data.

We will now present an example problem dealing with the hardware and software aspects of the RS-232 interface and serial data communications.

### Example 8.3 RS-232 data communications.

Design (1) operating hardware and (2) software based on Figure 8.6. The system will receive ASCII characters on RXD from the DCE at 300 baud with a start bit, seven data bits, odd parity, and two stop bits.

Echo the same character to the DCE on the TXD line. The DTE and DCE follow the standard RS-232 interface format discussed earlier.

| LINE ADDR                    |                                                               |
|------------------------------|---------------------------------------------------------------|
| 1.<br>2                      | ;RS232.SRC 11/22/88<br>;F.I.U                                 |
| -<br>3<br>4                  | OPT A                                                         |
| 4<br>5                       | ORG \$1000                                                    |
| 6 00010041                   | DECLARE 6450 ACIA REGISTERS<br>ACCR EQU \$010041 ;CONTROL REG |
| 7 00010041                   | ACSR EQU \$010041 ;STATUS REG                                 |
| 8 00010041                   | ACTDR EOU SOLOO41 TRANSMIT REG                                |
| 9 00010043                   | ACRDR EOU \$D10043 RECEIVE REG                                |
| 10;master r                  | eset and initialize the 6850 ACTA                             |
| 11 OCOO1000                  | 1 13FC 0003 0001 MOVE.B #\$03,ACCR ;MASTER RESET              |
| 12 00001004                  | 0041<br>17EC 8445 8981                                        |
| ής Π <b>ΠΑ</b> ΤΟΠΩ          | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1                         |
| 13:Checks r                  | arity, overrun, frame, DCD errors and CTS activity            |
| <u> </u>                     | 1 1 1 1 9 0 0 0 1 0 0 4 1 TYDA MOVE B BOCK DO                 |
| 15 88801816                  | DEDD UD7C ANDI.B #\$7C.DD : ANY ERRORS 2                      |
| 10 00000000                  | BNE.S INPT : IF SO LOOP                                       |
| 17;no error                  | S: proceed to check if the RDR is full                        |
| 18 0000101C                  | 1039 0001 0041 RECV NOVE.B ACSR,DD                            |
| - 14 00001030<br>74 00007055 | 0200 0001 ANDI.B #\$01,D0<br>67F4 BEQ.S RECV                  |
| 21 0000000E6                 | 1239 0001 0043 MOVE.B ACRDR, D1; RDR INTO D1                  |
| 22:transmit                  | the received character, if the TDR is empty                   |
| 23 0000105E                  | 1039 0001 0041 TNSM MOVE.B ACSR,DO                            |
| 24 00001034                  | 0200 0002 ANDI.B #\$02.00 :TS TDR EMPTY?                      |
| 25 00001038                  | 67F4 BEO_S TNSM                                               |
| 26 0000103A                  | 13C1 0001 0041 MOVE.B D1,ACTDR                                |
| 27 00001040<br>28 00001042   | 4.B.( J. NOP                                                  |
| 58<br>58                     |                                                               |
| 30;                          | ;                                                             |
| 31,<br>31,                   |                                                               |
| 32 00001044                  | END                                                           |
|                              |                                                               |
| ASSEMBLE                     | R ERRORS = O                                                  |

FIGURE 8.7 The 68000 software listings for the DTE/DCE interface.

### Solution

- 1. Hardware: The hardware of Figure 8.6 is self-contained. The internal control register of the 6850 should be configured to obtain a baud rate of 300 from the 4800-Hz external RXCLK and TXCLK inputs. This can be achieved by selecting the divide-by-16 option.
- 2. Software: The actual 68000 software listings to accomplish the task are given in Figure 8.7. It is necessary to reset the 6850 at the outset to eliminate any residual conditions from previous operations.

Between lines 10 and 12, the control register is configured for master reset. It is reinitialized with \$45 for the communication format as shown:

| ь7              | b6 | b5           | <b>b</b> 4 | b3                         | b2 | 51        | 60 |
|-----------------|----|--------------|------------|----------------------------|----|-----------|----|
| 0               | 1  | 0            | 0          | 0                          | )  | 0         | 0  |
| IRQ<br>disabled |    | rs<br>active |            | it odd-pari<br>d; 2 stop b |    | Div<br>by |    |

Between lines 13 and 17, the software polls the status register of the 6850 until the CTS input goes active and the error-free condition is detected. It then proceeds to the RECV module.

In the RECV module between lines 18 and 22, the software reads the received data byte when the RDR becomes full. The 6850 strips the start, parity, and stop bits from the incoming serial data on the RXD line, converts the serial data into a parallel data element, and places it in the RDR.

The character echo is accomplished by transmitting the received character back to the DCE by means of the TNSM module. Between lines 23 and 27, the software polls the status register until the TDR is empty. When the TDR is empty, the software writes the received data byte into it to be transmitted back (echoed) to the DCE unit. The 6850 adds the start, parity, and stop bits to the data in the TDR, generates a data frame, and serializes it on the TXD line. The BRA.S INPT instruction at line 28 loops the program back to line 14 for the next character.

The software we have just described can be very easily converted to terminal input and output software. The NOP instruction at line 27 can be changed to an RTS instruction and the current software can be called as a subroutine by a main program.

For example, the JSR INPT instruction in a main program enters the software at line 14, reads an input character from the terminal, and echoes it to the terminal. It then returns to the main program with the value of the input character in the Dl register.

The DCE system should have RS-232-compatible software in it. In the system of Figure 8.6, the RTS output of the 6850 ACIA goes high when the TDR is loaded with new data. This manifests as low on the /DTR line. The DCE system should poll this condition and accept the data accordingly.

### 8.4 68901 MFP (MULTIFUNCTION PERIPHERAL) GENERAL ARCHITECTURE

In addition to serial communication, need often arises for attendant control, timing, I/O, and interrupt functions. The 68901 MFP of the 68000 family is a multifunction device that is becoming an industry standard for integrated serial, parallel, timing, and interrupt applications. In this section, we will examine the architecture of the MFP. The MFP data book should be used as an additional reference.<sup>8</sup>

### Internal Architecture of the MFP

Figure 8.8 illustrates the pin configuration and internal architecture of the 68901 MFP. The device is contained in a 48-pin DIP and is fabricated with HMOS technology. It includes the following features:

four timers for timing applications;

one USART for serial data communications; one GPIP for 8-bit parallel I/O and external interrupt inputs; and control logic for the coordination of the various functions.

The A, B, C, and D timers accept external clock inputs from the XTL1 and XTL2 lines and provide timed pulses on the TAO, TBO, TCO, and TDO lines. In addition, the A and B timers can accept external timing inputs on the TAI and TBI lines and measure their time duration.

The USART (universal synchronous/asynchronous receiver and transmitter) provides serial output on the SO line. It accepts serial input on the SI line. The receive and transmit clocks are accepted on the RC and TC inputs and are used for the respective data-shifting operations within the USART.

The GPIP (general purpose I/O and interrupt port) has 8-bit parallel I/O capability on the 10-17 lines. These lines can also be configured as eight external interrupts. allowing the MFP to function as an interrupt controller. The associated interrupt control logic interlaces with the processor on the /IRQ and the /IACK lines. The /IEO and /IEI (interrupt enable output and input) signals are used for daisy chaining the priority interrupts.

The 68901 MFP communicates with the processor on an 8-bit data bus D0-D7. There are twenty-four 8-bit registers in the 68901, which are selected by the five register select inputs, RS1-RS5. The select and control logic consists of the CS (chip select), DS (data strobe), and R/\*W (read/write) inputs and the /DTACK (data acknowledge) output. The RESET input provides the 68901 reset operation. The CLK input advances the

internal states of the MFP.

In this section we will discuss some details of the registers dealing with the GPIP. USART, and timers, emphasizing the utility of the MFP in serial communication applications. We will deal with the interrupt-related registers in Chapter 9.

### Register Structure and Modes of Operation

Figure 8.9 is a tabular representation of the MFP's internal register structure. Contents written into the appropriate registers determine the mode of operation of the MFP. Similarly, some of the status registers contain status information about events occurring in the MFP. The processor reads this status information, interprets it, and performs appropriate operations as determined by the software.9



FIGURE 8.8 (a) Pin diagram of the 68901 multifunction peripheral (MFP) and (b) architecture.

| Number* | Symbol | Name                            | Function                        |
|---------|--------|---------------------------------|---------------------------------|
| 0 1     | GPIP   | General-purpose I/O register    | I/O and interrupt interface     |
| 03      | AER    | Active edge register            | Specifies edges                 |
| 05      | DDR    | Data direction register         | Specifies GPIP direction        |
| 0 7     | IERA   | Interrupt enable register A     | Interrupt enable/disable        |
| 09      | IERB   | Interrupt enable register B     | Interrupt enable/disable        |
| 0 B     | IPRA   | Interrupt pending register A    | Pending interrupts              |
| 0 D     | IPRB   | Interrupt pending register B    | Pending interrupts              |
| 0 F     | ISRA   | Interrupt in-service register A | Interrupt service specify       |
| 11      | ISRB   | Interrupt in-service register B | Interrupt service specify       |
| 1 3     | IMRA   | Interrupt mask register A       | Masks interrupts                |
| 15      | IMRB   | Interrupt mask register B       | Masks interrupts                |
| 17      | VR     | Vector register                 | Interrupt vector number         |
| 19      | TACR   | Timer A control register        | Specifies timer A               |
| 1 B     | TBCR   | Timer B control register        | Specifies timer B               |
| I D     | TCDCR  | Timers C and D control register | Specifies timers C and D        |
| ιF      | TADR   | Timer A data register           | Timer A count number            |
| 21      | TBDR   | Timer B data register           | Timer B count number            |
| 23      | TCDR   | Timer C data register           | Timer C count number            |
| 25      | TDDR   | Timer D data register           | Timer D count number            |
| 27      | SCR    | Synchronous character register  | Specifies synchronous character |
| 29      | UCR    | USART control register          | Specifies USART                 |
| 2 B     | RSR    | Receiver status register        | Receiver status                 |
| 2 D     | TSR    | Transmitter status register     | Transmitter status              |
| 2 F     | UDR†   | USART data register             | Receiver/transmitter data       |

\*Relative increment with respect to the base address. \*Receive register in read mode; transmit register in write mode.

FIGURE 8.9 The 68901 MFP internal register structure.

- -

GPIP (General-Purpose I/O and Interrupt) Port The following three registers determine the mode of operation of the GPIP port:

GPIP (general-purpose I/O register): at displacement \$01; AER (active edge register): at displacement \$03; and DDR (data direction register): at displacement \$05.

Zero in a bit position of the DDR makes the corresponding GPIP line an input, and vice versa. Zero in a bit position of the AER causes an interrupt to be generated on the falling edge of the corresponding GPIP input line, and vice versa. These interrupts can be masked out by the interrupt mask registers, whereupon the GPIP inputs become normal inputs.

| FIGURE 8.10 Timer C and D        |               | b7     | b6     | b5     | <b>b</b> 4 | b3    | b2      | bl      | ъ0      |         |
|----------------------------------|---------------|--------|--------|--------|------------|-------|---------|---------|---------|---------|
| control register (TCDCR) format. | TCDCR at \$1D | 0      | CC2    | CCI    | CC0        | 0     | DC2     | DCI     | DC0     |         |
|                                  |               | ⇔⊺     | imer C | contro | ગ ⇒        | 🗢 1   | Fimer I | ) contr | ol⇒     | İ       |
|                                  |               | CC2    | CC1    | C      | C0         | Timer | C oper  | ation n | node    |         |
|                                  |               | DC2    | DCI    | D      | C0         | Timer | D oper  | ation 1 | node    |         |
|                                  |               | 0      | 0      |        | 0          |       |         | er stop |         |         |
|                                  |               | 0      | 0      |        | 1          | Delay | mode:   | divide  | -by-4 р | rescale |
|                                  |               | ñ      | 1      |        | 0          |       | н       | 11      | 10      | н       |
|                                  |               | ŏ      | í      |        | 1          |       | н       | м       | 16      |         |
|                                  |               | ĩ      | Ô      | 1      | n<br>N     |       |         |         | 50      |         |
|                                  |               | i<br>í | ŏ      |        | ĩ          |       | 4       |         | 64      | "       |
|                                  |               | ړ<br>۱ | ĭ      |        | 0          |       | 14      | 11      | 100     | 11      |
|                                  |               | 1      | l      |        | 1          |       | п       | н       | 200     | н       |

USART Operation and Control The USART can be configured to operate in a synchronous or an asynchronous mode, with different word formats and baud rates. The UDR (USART data register) at displacement address \$2F acts as a receive data register during receive operations and as a transmit data register during transmit operations. The UCR (USART control register) at displacement address \$29 controls the USART modes as shown in Figure 8.11.

The RSR (receive status register) and TSR (transmit status register) at displacement addresses \$2B and \$2D contain the receiver and transmitter status information as shown in Figure 8.12. In our discussion, we will focus on asynchronous serial communications, since they are more widely used. The MFP is also capable of synchronous communications. These involve synchronous protocols and are more complex than asynchronous communications.

We will now present an example problem to enhance our understanding of the MFP architecture and register formats.

FIGURE 8.11 USART control register (UCR) format.

0 1 1/16 clock 00 8 bits ┥

01 7 bits 10 6 bits

11 5 bits

|   | b7         | BF                    | I⇒      |                  |
|---|------------|-----------------------|---------|------------------|
|   | b6         | OE                    | 1⇒      |                  |
|   | b5         | PE                    | 1⇒      |                  |
|   | b4         | FE                    | I⇒      |                  |
|   | b3         | B*                    | I⇒      |                  |
| ĺ | b2         | CIP*                  | 1⇒      |                  |
|   | b1         | \$S*                  | 1⇒      |                  |
|   | bO         | RE                    | I⇒      |                  |
|   | *These     | e bits have different | meaning | in synchro       |
|   | (a)        |                       |         |                  |
|   | 67         | BE                    | ,1⇒     | transm           |
|   | b6         | UE                    | I⇒      | underr           |
|   | b5         | AT                    | l⇒      | auto tu          |
|   | b4         | END                   | l⇒      | end of           |
| ł | b3         | <b>B</b> *            | l⇒      | break (          |
|   | b2         | H*                    | HL      | = 00 🔿           |
| Ì | b1         | L*                    |         | 01 ⇒             |
|   |            |                       |         | $10 \Rightarrow$ |
|   |            |                       |         | 1) ⇒             |
|   |            |                       |         | nally c          |
|   | <b>b</b> 0 | TE*                   | l⇒ tra  | ansmitter        |
|   | *The p     | rocessor writes thes  | e bits. |                  |
| - | -          |                       |         |                  |

(b)

FIGURE 8.12 (a) USART receive status register (RSR) and (b) transmit status register (TSR) structure.



mit buffer empty тип еггог turnaround (receiver enabled after transmit) transmission after which transmitter disabled character to be transmitted next SO high Z SO low [SO output control] SO high loop back (transmitter and receiver are interconnected) r enable

### Example 8.4 68901 registers and architecture.

In a particular data communication application, the MFP is initialized with the following hex values in the registers:



Using the information presented on the 68901 MFP,

- 1. specify how the GPIP is configured;
- 2. specify how the USART is configured;
- 3. specify how timers C and D are configured.

Solution (Refer to Figures 8.9 through 8.12.)

port (17-10) as an output. The GPIP register contents 07 = 0.0000111 are output to the port making

### $I7-I0 \Rightarrow 0\ 0\ 0\ 0\ 1\ 1\ 1$

2. USART: \$94 = 10010100 is written into the UCR. As such, the USART is configured for an 8-bit odd-parity word with one start and 1.5 stop bits. The shift clock is 1/16 of the respective RC (receive) and TC (transmit) clock inputs.

RSR contains \$01 = 0.0000001

and

### TSR contains \$05 = 0.0000101

By writing 1 into b0 of RSR and TSR, both the receiver and the transmitter are enabled. The SO (serial output) is held at high level (b2 of TSR = 1) during inactive transmission.

### 3. Timers C and D:

and

TCDCR contains 11 = 0.0010001

Both timers are configured for a delayed and prescaled mode. Divide-by-4 prescaling has been selected (b4 and b0 = 1 in TCDCR). Further divide-by-4 action has been selected (b2 = 1 in TCDR and TDDR). This provides divide-by-16 action for both timer outputs TCO and TDO with reference to the crystal clock input.

The unused registers of the MFP do not effect the other operations. The reset condition of the MFP leaves most of these registers in a default state, which leaves the MFP in an inactive condition with disabled interrupts.

### 8.5 68901 MFP INTERFACE WITH THE 68000 AND APPLICATIONS

The 68901 MFP is a 68000-compatible I/O device. The multifunction capabilities of the 68901 make the I/O interface and applications very efficient and powerful.

### 68000/68901 and I/O Interface Considerations

Figure 8.13 illustrates the interface details of the 68901 with the 68000 processor and the I/O systems. The address decoders (refer to Section 6.3 of Chapter 6) generate the required chip select to the MFP. The system reset signal drives the MFP to reset the MFP and set default values in the registers. The R/\*W signal is interfaced directly for read/write operations.<sup>10</sup>

The MFP is mapped on the lower data byte D7-D0 to facilitate direct transfers of the interrupt vector numbers from the MFP to the processor. The /LDS signal drives the /DS (data strobe) input for the lower byte data transfers. The A5-A1 address lines drive the register select lines RS5-RS1 to address one of the internal 24 registers of the MFP. The /DTACK is fed back to the processor through the interface logic. The clock input is the same as that for the processor. Another MFP can be mapped on upper byte of the data bus by using the /UDS signal in place of the /LDS. Both MFP devices together occupy the 16-bit data bus for effective word transfers.

The SO and SI (serial out and serial in) lines are interfaced to the serial I/O unit. The 2.4576-MHz crystal activates the MFP for proper timing of the timers and the USART. The TCO and the TDO timer outputs are fed back as the RC and the TC clock inputs. The GPIP I/O port drives an LED display. For the conditions of Figure 8.13, the base address of the MFP is \$040000. The GPIP is located at \$040001, and so on.

TCDR and TDDR contain \$04 = 0.0000100



FIGURE 8.13 The 68901 MFP interface with the 68000 and with I/O systems (Example 8.5).

### Coded Data Communication System

In order to maintain security, data may be coded during data communications. The 68000/68901 system of Figure 8.13 is well suited for such an application. The data are transmitted on the SO line to the I/O system in a coded form and are echoed back on the SI line of the MFP. The microprocessor reads and further codes the data, and displays the data on the GPIP port LED bank. The coding used for the data communication is the data inversion. The coding used for the display is to advance to the next ASCII value. The characters to be transmitted are in a memory buffer. A0 refers to the starting address and Al refers to the ending address of the buffer.

Figure 8.14 indicates the 68000-based software for this coded data communication system. Between lines 6 and 16, the MFP registers that are relevant to this application are defined. Between lines 17 and 32, the MFP is initialized as follows (refer to Example 8.4 for details):

| LI          | NE           | ADD                          | R       |              |           |     |           |      |            |     |     |    |
|-------------|--------------|------------------------------|---------|--------------|-----------|-----|-----------|------|------------|-----|-----|----|
| 1<br>2<br>3 | ;MFH<br>;fit | ?.SR<br>2 2/0                | С<br>39 | C <b>0</b> I | ΈD        | DA  | TA        | C0   | MMI        | JN  | IC  | A  |
| 4           | ,            |                              |         |              |           |     |           |      | 0 P 1      |     |     |    |
| 5           |              |                              |         |              |           |     |           |      | OR         | 3   | \$L | 0  |
|             |              | TNE                          |         |              |           |     | R         |      |            |     |     |    |
| ?           | 000          | 1400                         | 00      | E            | BAŞ       | E   |           |      | EQC        | J   | \$0 | 4  |
| 8           | 000          | 1400<br>1400<br>1400<br>1400 | 01      | 6            | <b>PI</b> | Р   |           |      | EQU<br>EQU | J   | ΒA  | S  |
| 9           | 000          | 1400                         | 05      | Ι            | DR        |     |           |      | EQU        | J   | BA  | S  |
| 10          | 000          | 1400                         | 1 D     | 1            | CD        | CR  |           | 1    | ΕÕι        | J   | BA  | S  |
| 11          | 000          | 1400                         | 23      | 1            | CD        | R   |           | 1    |            |     |     |    |
| 15          | 000          | 1400                         | 25      | I            | ) D R     |     |           | 1    | EQI        | 1   | ΒA  | s  |
| 13          | 000          | 1400                         | 29      | - C          | ICR       |     |           | ]    | EQI        | J   | BA  | S  |
| 14          | 000          | 1400                         | 2B      | E            | ≷SR       |     |           | ]    | EQI        | J   | BA  | S  |
| 15          | 000          | )400<br>)400                 | 2D      | 1            | 'S R      |     |           | 1    | EQU        | J   | BA  | S  |
| 76          | ЫПГ          | 14UU                         | сr      | ι            | IDK       |     |           |      | EQU        |     | BA  | S  |
| 17;         | ;IN]         | TIA                          | LI      | ZE           | GP        | IP  | AS        | 00   | ΤΡL        | JT  |     |    |
|             |              | TIA                          | LI      | ΖE           | ΤI        | MER | S (       | C&D  | 11         | 4   | DI  | V  |
| 19          |              |                              |         |              |           |     |           |      |            |     |     |    |
| 50          | 000          | 010                          | 00      |              |           |     | FF        | 00   | 84         | Ι   | NI  | T  |
|             |              |                              |         |              | 105       |     |           |      | _          |     |     |    |
| 21,         | 000          | 010                          | 08      |              |           |     | 00        | 00   | 04         |     |     |    |
|             |              |                              |         |              | 101       |     |           |      |            |     |     |    |
| 55          | 000          | 1010                         | 10      |              |           |     | 02        | 001  | 04         |     |     |    |
|             |              |                              |         |              | 153       |     |           |      | _ ,        |     |     |    |
| 23          | UUL          | 1010                         | 10      |              |           |     | 99        | 001  | 04         |     |     |    |
|             |              |                              |         |              | 125       |     |           |      |            |     |     |    |
| 24          | UUU          | 1010                         | ď۵      |              |           | Uυ  | 11        | ΟIJ  | 4          |     |     |    |
| 75          |              | <b>D G</b>                   | <b></b> |              | 11D       | ~ ~ |           |      |            |     |     | _  |
|             |              | RT                           |         |              |           |     |           |      |            |     |     |    |
|             |              | TAR                          | T,      | ä            | DA        | ΓA, | 01        | ו ענ | PAP        | (1) | ľΥ  | 4  |
| 27;         |              |                              |         |              |           | ~~  |           | ~ ~  |            |     |     | -  |
| 20          | υUU          | 010                          | сõ      |              |           |     | 44        | υUi  | 4          | 11  | T N | T) |
| 29          | 000          | 010                          | 30      |              | P2        |     | <b>11</b> | ODO  |            |     |     |    |
| 67          | 000          | 010                          | JU      |              | 12B       | ыU  | ul ul     | UUU  | 94         |     |     |    |
|             |              |                              |         | υu           | CD        |     |           |      |            |     |     |    |
|             |              |                              |         |              |           |     |           |      |            |     |     |    |

FIGURE 8.14 Coded data communication software for the 68901/68000-based system (Example 8.5).

GPIP is configured as an 8-bit parallel output port; USART is configured for 9600 band, 8 data bits with 1 start and  $l_{\frac{1}{2}}^{\frac{1}{2}}$  stop bits, and odd parity;

Timers TC and TD are in a divide-by-16 mode.

Between lines 33 and 40, the transmit character routine is performed. The character from the memory buffer referenced by the A0 register is read into DO. It is coded by logical inversion and transmitted on the SO output. This is accomplished by checking bit 7 of the TSR for logical 1 (signifying that the USART transmit buffer register UDR is empty) and then writing the data byte in DO into the UDR, if it is empty.

ATION 000 0000 ;BASE REG SE+\$01 ;GPIP PORT SE+\$05 ;DATA DIR REG SE+\$1D ;TIMER C/D CONTROL E+\$23 ;TIMER C DATA REG SE+\$25 ;TIMER D DATA REG 5E+\$29 ;USART CONTROL REG SE+\$2B RCVR STATUS REG SE+\$2D ;TNSMT STATUS REG SE+\$2F ;USART DATA REG VIDE BY 16 MODE C1 MOVE.B #\$FF,DDR ;GPIP OUT MOVE.B #\$00,GPIP MOVE.B #\$D2,TCDR MOVE.B #\$02,TDDR MOVE.B #\$11, TCDCR FURTHER DIVIDE BY 16 & 1 1/2 STOP BITS C2 MOVE.B #\$94,UCR ;FORMAT MOVE.B #\$01,RSR ;ENABLE RCVR

30 00001038 13FC 0005 0004 MOVE.B #\$05,TSR ;ENABLE TSMTR 0020 31 00001040 4E?1 NOP 32 00001042 4E?1 NOP 33; READ IT FROM CHARACTER BUFFER SEQUENTIALLY, CODE IT 34; AND TRANSMIT. AO BEGINNING AND AL END OF BUFFER START MOVE.B (AO)+,DO ;IN DO 35 00001044 1018 EORI.B #\$FF,DO ;INVERT IT 36 00001046 0A00 DOFF 37 0000104A 0839 0007 0004 TRSMT BTST.B #\$7,TSR 0020 BEO.S TRSMT 38 00001052 67%6 ;CHRCTR IN MOVE.B DD,UDR 39 00001054 13C0 0004 002F 40 0000105A 4E71 NOP ; PORT 41; RECEIVE CODED CHARACTER FROM SERIAL PORT INTO D1 42 0000105C 0839 0007 0004 RCEVE BTST.B #\$7,RSR 8500 43 00001064 67F6 RCEVE BEQ.S MOVE.B UDR, D1 ; CHRCTR INTO D1 44 0001066 1239 0004 002F 45 0000106C 0A01 00FF EORI.B #\$FF,D1 ;INVERT IT 46; CODE AGAIN AND SEND IT TO GPIP LED DISPLAY DSPLY ADDI.B #\$01,D1 ;NEXT 48 00001070 0601 0001 49 00001074 1301 0004 0001 MOVE B D1,GPIP 50; SHORT DELAY AND CHECK END OF BUFFER #\$OF00,D2 MOVE.W 51 0000107A 343C OF00 LOOP SUBQ.W S2 0000107E S342 #\$01,D2 53 00001080 66FC BNE.S LOOP ;END OF BUFFER CMPA.L AO,A1 54 00001082 B3C8 BNE.S START ;NO: TO START 55 00001084 66BE WAIT BRA.S WAIT:WAIT LOOP 56 00001086 60FE 57 00001088 4E71 NOP 58: 59: 60 0000108A END ASSEMBLER ERRORS = 0

FIGURE 8.14 Continued.

Between lines 41 and 49, the receive character routine is performed. The echoed character from the serial I/O on the SI input is read into Dl after checking that the receive buffer is full. It is decoded by logical inversion. It is further coded to be the next ASCII character by adding 1 to it. Finally, it is output to the LED display on the GPIP output port.

Between lines 50 and 53, a delay routine is incorporated. At lines 54 and 55, the program checks for the end of the buffer. If the end of the buffer is not indicated, the program loops back to start. At line 56, the program goes into an indefinite wait loop.

The following example problem provides a review of the 68000/68901 interface and the coded data communication.

Example 8.5 68000/68901 coded data communication. Consider the hardware and software of Figures 8.13 and 8.14.

- 1. What are the baud rates for data transmission and receiving?
- 2. Show how character A will be transmitted on the SO line.
- 3. Show how character A will be displayed on the LED array.
- 4. When does the WAIT loop at line 56 end? Why is it used?

### Solution

1. Baud rates: The TCDR, TDDR, and the TCDCR are effectively configured for a (connected as RC and TC inputs) are at

The UCR (USART control register) is configured for a divide-by-16 mode to obtain effective shift baud rates, given by

### 2. Transmission of character A:

The transmitted data on SO will be as shown:



3. Display on the LED array: The received character in the inverted form is inverted back to the original character A. It is then coded to be the next ASCII character B. The ASCII code for B is \$42; thus, the LED array displays

0 LED off: 1 LED on.

4. WAIT loop: The WAIT loop can be terminated only by an external interrupt or reset condition. In situations requiring external excitation, the software wait loops are used,

divide-by-16 mode for the crystal input clock. Thus, TCO and TDO timer outputs

2.4576 MHz/16 = 153.6 KHz

Receive baud rate = RC/16 = 9600 baud Transmit baud rate = TC/16 = 9600 baud

ASCII code for character A =  $0 \mid 0 \mid 0 \mid 0 \mid 0 \mid \Rightarrow \$41$ Inverted code for character  $A = 10 | 111110 \Rightarrow$  \$BE

The 68901 adds the start, odd-parity, and  $l_{\overline{2}}^{\frac{1}{2}}$  stop bits to the preceding inverted data.

 $\$42 \Rightarrow 0100010$ 

The coding in the preceding example is simple. However, it can be made as complex as required. The  $\mid$  stop-bit concept implies that the second stop bit is only half the period of the shift clock. However, the shift clock is 1/16 the frequency of the TC and the RC clock inputs. As such, the half stop bit can be accurately sampled by the RC and TC clocks. The half stop bit is intended to make the data frame more efficient.

### 8.6 SUMMARY

In this chapter we introduced some important serial data communication concepts. For interfacing slower peripherals and systems to a fast processor, serial communication is preferable to parallel communication. The standard asynchronous serial data frame consists of a stop bit, a data element, a parity bit, and one or two stop bits. The parity bit is for error checking. With serial interface, the number of external connections to the processor interface are reduced. This results in a cost efficient, less complex interface.

One of the industry standard serial communication devices for RS-232 serial communications is the 6850 ACIA (asynchronous communication interface adapter) of the earlier 6800 family. It consists of four internal registers: the control register, the status register, the transmit register, and the receive register. It accepts an 8-bit parallel word from the processor, converts it into RS-232 format, and serializes the data frame for "transmission on the serial data link. Similarly, it accepts the serial data from the data link, checks the parity, removes the extra bits in the serial frame, converts it into an 8-bit parallel word, and supplies it to the processor.

We described interfacing the 68000 using the 6850 ACIA. We also described the industry standard RS-232 serial interface using the 6850 ACIA, including the details of a hardware and software application.

The 68901 MFP (multifunction peripheral) is a very useful device belonging to the 68000 family. We described its internal architecture and the particulars of the 68000/ 68901 MFP interface. The MFP device has integrated capabilities for serial data communications, timing, parallel I/O, interrupts, and DMA. It is particularly useful as a serial communication device.

The coded data communication example we presented was meant to provide a practical application of the MFP device and also illustrate the concept of data security in transmission and receiving. It should be noted, however, that there are more efficient data security methods than the one we considered.

### PROBLEMS

8.1 Configure the control register of the ACIA to

(a) transmit an 8-bit odd-parity word with one stop bit;(b) transmit a 7-bit even-parity word with two stop bits.

Consider an active low RTS in both cases. Use the divide-by-64 option at a 300 baud rate. Interrupts are disabled.

- 8.2 Repeat Problem 8.1 assuming that the data are to be received rather than transmitted.
- **8.3** The following message has been transmitted using the divide-by-16 option at 1200 baud with a 7-bit odd-parity format with one start bit and two stop bits:

### 6850 IS ACIA

(a) Specify the word frame for each of the characters using ASCII code.(b) Specify the contents of the control register.

- 8.4 Repeat Problem 8.3 when an 8-bit frame with two stop bits and no parity is used.
- 8.5 Can the TX and RX baud rates be different? Explain.
  - (a) If they can be different, how can this be accomplished?
  - (b) What additional hardware would be required to achieve different baud rates for TX and RX?
- 8.6 Redesign the RS-232 interface of Figures 8.6 and 8.7 for data communications at (a) 110 baud;
  - (b) 4800 baud.
- 8.7 For the 6850 ACIA/RS-232 interface, design the necessary hardware and software
  - (a) to receive 256 characters of data as a block at 600 baud and store the data in a buffer, with a 7-bit even-parity character format;

(b) to transmit the data at 300 baud after the entire block has been received.

8.8 Design a 6850-based coded data transmission system that will

(a) receive an ASCII character and also transmit the next highest ASCII character;(b) receive an ASCII character and also transmit the next lowest ASCII character.

8.9 Repeat Problem 8.8 so that the higher and lower ASCII characters are transmitted for each received character as shown:

| Received characters:    | в   | К  | М  |
|-------------------------|-----|----|----|
| Transmitted characters: | A C | JL | LN |

- **8.10** Can the 68901 MFP perform several functions simultaneously in real time? Can it operate at a frequency different from that of the processor? Explain your answers,
- 8.11 Using Example 8.4, with the crystal at 2.84596 MHz,
  - (a) what are the TCO and TDO frequencies?
  - (b) if the TCO and TDO are used as the RC and TC clock inputs, what are the effective shift rates of the receive and transmit shift registers of the 68901?
- **8.12** Reconfigure the 68901 MFP so that the GPIP has the lower nibble as the input and the upper nibble as the output. Specify the control words to be written into the appropriate registers.
  - (a) When outputting data on the GPIP, how do the pins configured as inputs behave?(b) When entering the data, what is read on the pins configured as outputs?

- 8.13 Reconfigure timers C and D for
  - (a) delayed divide-by-64 prescale activity for both;
  - (b) delayed divide-by-200 prescale activity for both with additional divide-by-4 action in the 68901.
- 8.14 Can the C and D timers of the 68901 MFP count external events? Why or why not?
- 8.15 In the system of Figure 8.13, specify the redundant locations for the 68901 MFP registers.
- 8.16 Redesign the system of Figure 8.13 to allow for two MFP devices occupying the lower and upper memory bytes. Indicate all of the hardware details.
- 8.17 Redesign the software of Figure 8.14 so that reverse coding is done while transmitting a received character. For example

Received character code A 
$$\Rightarrow$$
 0100001  $\Rightarrow$  \$41  
Transmitted character code  $\Rightarrow$  1000010  $\Rightarrow$  \$82

8.18 Redesign the system of Figure 8.13 so that

(a) the receive and the transmit baud rates are 1200; (b) the receive baud rate is 1200, but the transmit baud rate is 600.

8.19 Repeat Problem 8.17 so that there is reverse coding and also code inversion. For example,

| Received character code A                 | $\implies 0 \ 1 \ 0 \ 0 \ 0 \ 0 \ 1 \implies \$41$ |
|-------------------------------------------|----------------------------------------------------|
| Reverse code                              | $\Rightarrow$ 1 0 0 0 0 0 1 0 $\Rightarrow$ \$82   |
| Inverted reverse<br>code for transmission | $\Rightarrow$ 0 1 1 1 1 0 1 $\Rightarrow$ \$7D     |

### **ENDNOTES**

- 1. Harman, T., and Lawson, B. The Motorola MC68000 Microprocessor. Englewood Cliffs, NJ: Prentice-Hall, 1985.
- 2. Gaonkar, R. Microprocessor Architecture, Programming, and Applications with the 8085/8080A. Columbus, OH: Merrill, 1984.
- 3. Gibson, M., and Liu, C. Microcomputers for Scientists and Engineers. Englewood Cliffs, NJ: Prentice-Hall, 1987.
- 4. Motorola, Inc. Data Sheets on M6850 ACIA. Phoenix, AZ: Motorola Technical Operations, 1986.
- 5. Subbarao, W. Microprocessors: Hardware, Software, and Design Applications. Englewood Cliffs, NJ: Prentice-Hall, 1984.
- 6. Triebel, W., and Singh, A. "8086 Microprocessors." Chap. 12 in 16-Bit Microprocessors: Architecture, Software and Interfacing Techniques. Englewood Cliffs, NJ: Prentice-Hall, 1985.

- Motorola Microprocessor Group, 1981.
- 1984
- Austin, TX: Motorola Microprocessor Group, 1984. 10. Motorola, Inc. MC68000 Data Book. Phoenix, AZ: Motorola Technical Operations, 1983.

7. Melear, C. Asynchronous Communications for MC6850. App. Note #817. Austin, TX: 8. Motorola, Inc. MC68901 MFP Data Book. Phoenix, AZ: Motorola Technical Operations,

9. Brown, G. Serial I/O, Timer, and Interface Capabilities of the 68901. App. Note #896.

## CHAPTER

y

## The 68000 Interrupt and DMA Interface and Applications

### Objectives

In this chapter we will study:

Interrupt interface schemes associated with the 68000 Interrupt expansion schemes and daisy chaining Interruptdriven system applications The DMA interface and controllers DMA system interface design

### 9.0 INTRODUCTION

An interrupt is the traditional way in which the attention of the processor is obtained by an external device or a peripheral. By contrast, DMA (direct memory access) is the traditional way of obtaining control of the processor buses and is used by I/O systems for high-speed data transfers.

Interrupts are handled in the supervisor mode. The terms /IRQ and /INT are used interchangeably in this chapter to refer to the interrupt request. Study of the material to be presented will help the reader understand the interrupt and DMA structure of the 68000 family of processors so as to implement interrupt-based I/O systems and DMA-based data transfers.





237

. .. . .. ..

The reader is advised to review the concepts in Chapter 5 related to exception vectors and interrupts (Sections 5.1 and 5.2) before proceeding further.

### 9.1 INTERRUPT INTERFACE CONSIDERATIONS

### Autovectored and User-vectored Interrupt Logic

Figure 9.1 (p. 237) illustrates the autovectored and user-vectored interrupt logic associated with the 68000 processor. The I/Q-2 device generates interrupt request /INT3, which is encoded onto the /IPL2, /IPL1, and /IPLO inputs of the processor by the 74LS148 encoder. In response to /INT3, the processor generates an /IACK3 interrupt acknowledge signal, which is gated as /VPA input to the processor for **autovectoring**. During the interrupt acknowledge cycle, the FC2, FC1, and FCO outputs of the processor remain at the 111 condition; the A3, A2, and A1 address lines contain the interrupt number that is being acknowledged. In this case, A3, A2, and A1 <u>will be</u> at 011.

The I/O-1 device generates interrupt request /INT5. The processor generates the corresponding /IACK5 interrupt acknowledge <u>signal</u>, which is routed to the interrupt controller of the I/O-1 device. In response to /IACK5, the controller provides the interrupt vector number on the data bus and activates the /DTACK input to the processor for **user vectoring.** In either case, the processor goes to the appropriate vector location as outlined in Chapter 5, and executes the interrupt service routine in the supervisor mode.<sup>1</sup>

| Priority      | Channel | Description           |
|---------------|---------|-----------------------|
| highest \$0F  | 1 1.1 1 | GPIP interrupt 17     |
| \$0E          | 1110    | GPIP interrupt 16     |
| \$0D          | 1101    | Timer A               |
| \$OC          | 1100    | Receive buffer full   |
| \$ <b>0</b> B | 1011    | Receive error         |
| \$0A          | 1010    | Transmit buffer empty |
| \$09          | 1001    | Transmit error        |
| \$08          | 1000    | Timer B               |
| \$07          | 0111    | GPIP interrupt 15     |
| \$06          | 0110    | GPIP interrupt 14     |
| \$05          | 0101    | Timer C               |
| \$04          | 0100    | Timer D               |
| \$03          | 0011    | GPIP interrupt I3     |
| \$02          | 0010    | GPIP interrupt 12     |
| \$01          | 0001    | GPIP interrupt II     |
| lowest \$00   | 0000    | GPIP interrupt I0     |

FIGURE 9.2 The 68901 MFP interrupt channels and priority structure. (Courtesy of Motorola, Inc.)

### Interrupt Controllers

An **interrupt controller** is a device that can prioritize interrupts, provide vector numbers to the processor, and keep track of the occurrence of the interrupts. The 68901 MFP introduced in the previous chapter is such an interrupt controller belonging to the 68000 family. The MFP handles 16 interrupt channels (8 from the internal sources and 8 from the external GPIP lines 10-17 used as interrupt inputs). In Figure 9.2 the priority structure of these interrupt channels is indicated. (Refer to Chapter 8 for 68901 MFP details.) The MFP controls these interrupts using

the interrupt enable registers A and B (IERA and IERB); the interrupt mask registers A and B (IMRA and IMRB); the interrupt pending registers A and B (IPRA and IPRB); the interrupt in-service registers A and B (ISRA and ISRB); and the interrupt vector register (VR).<sup>2</sup>

Figure 9.3 illustrates the format of the IERA and IERB. These two registers enable or disable the interrupts. If the bit is set (= 1), the corresponding interrupt is enabled. If the bit is reset (=0), the corresponding interrupt is disabled. When the interrupt is enabled, its occurrence will be recognized by the MFP, and the /IRQ will be asserted to the processor. All the other interrupt-related registers have bit maps similar to that of the IERA/IERB.

Interrupts are masked for a channel by clearing the appropriate bit to 0 in the mask registers 1MRA/IMRB. When an interrupt is enabled but masked, it will be recognized by the MFP, but the /IRQ will not be asserted to the processor. Instead, the corresponding bit in the interrupt pending registers IPRA/IPRB will be set. The processor can poll these registers to determine if an interrupt has occurred.

|                     | 67        | b6         | b5         | b4               | b3           | b2               | b1            | ь0         |
|---------------------|-----------|------------|------------|------------------|--------------|------------------|---------------|------------|
| IERA at<br>dis \$07 | GPIP<br>7 | GPIP<br>6  | TIMER<br>A | R. BUFF<br>empty | RCV<br>error | T. BUFF<br>empty | TMIT<br>error | TIMER<br>B |
|                     | b7        | b6         | b5         | b4               | b3           | b2               | ы             | b0         |
| IERB at<br>dis \$09 | GPIP<br>5 | GPIP<br>4  | TIMER<br>C | TIMER<br>D       | GPIP<br>3    | GPIP<br>2        | GPIP<br>1     | GPIP<br>0  |
|                     | b7        | <b>b</b> 6 | b5         | b4               | b3           | Ъ2               | ь1            | b0         |
| VR at<br>dis \$17   | V7        | V6         | V5         | V4               | IV3          | IV2              | IVI           | IV0        |
|                     | ×——       | User-      | written 🗔  | >:               | <            | MFP-su           | applied 🚞     | >:         |
|                     |           | di         | s 🆈 displa | cement addr      | ess of the   | MFP register     | s.            |            |

FIGURE 9.3 Structure of the interrupt enable registers, IERA and IERB, and the vector register, VR.

When a bit in the ISRA/ISRB is set, it implies that the corresponding interrupt vector number has been given to the processor and that the interrupt routine is in progress.

For external GPIP interrupt inputs, the active edge register (AER) of the MFP is used to specify the edge activation. A zero in a bit position makes the corresponding interrupt active on a high-to-low transition, and vice versa.

The interrupt vector number is contained in the vector register (VR), as indicated in Figure 9.3. The upper four bits are written by the user during initialization. The lower four bits are written by the MFP according to the priority scheme of Figure 9.2.

### Interrupt Expansion and the Daisy-Chain Mechanism

In 68000-based systems, the MFP interrupt controllers are assigned to one of the seven possible interrupt levels of the processor. Each MFP supports up to 16 interrupts (8 internal and 8 external). However, in systems that are I/O-based to a large extent, there may be a requirement to increase the number of interrupt inputs. This can be accomplished by daisy chaining the interrupt controllers, as shown in Figure 9.4. The controller closest to the processor (MFP 1, in this case) has the highest priority. It is always enabled by keeping its interrupt enable input, /IEI, grounded.



FIGURE 9.4 Interrupt expansion using the daisy-chain mechanism.

When the processor recognizes the interrupt request on the common INT line, it sends the acknowledge signal IACK to the controllers. Suppose the interrupt request has come from MFP 1. MFP 1 accepts the IACK signal, puts the corresponding vector number on the data bus, and activates the DTACK to the processor. At the same time, it negates its interrupt enable output, /IEO. This, in turn, disables the next controller by deactivating its interrupt enable input, /IEI.

its /IEO output and enables the MFP 2 controller during the interrupt acknowledge . cvcle. MFP 2, in turn, supplies the vector number to the processor in response to the /IACK signal. This enable and disable process continues until the end of the chain.

of controllers on the daisy chain.<sup>3</sup>

The following example problem provides a review of the interrupt interface to the 68000 and the daisy-chain mechanism.

### *Example 9.1 68000 interrupt interface and daisy chain.*

Assume that the /IRQ outputs from the daisy-chained controllers of Figure 9.4 activate the /IRQ5 input to the 68000 system. (/IRQ and /INT refer to the same thing.)

### Solution

- Thus, interrupt 16 from MFP 1 will be recognized.
- ure 9.3).

0 in the bit position disables the interrupt;

1 in the bit position enables the interrupt.

The mask registers IMRA/IMRB have a similar bit map.

0 in the bit position masks the interrupt; 1 in the bit position does not mask the interrupt.

On the other hand, if we assume that MFP 2 has generated the /INT, MFP 1 activates

In the preceding case, it can be seen that a single /INT line can be expanded to handle 32 interrupts (16 from each controller). The number of entries in the vector table and the electronic loading on the lines determine the practical upper limit for the number

1. Interrupt 17 from I/O system 2 and interrupt 16 from I/O system 1 occur simultaneously and activate the /IRO5 line to the processor interface logic. Which interrupt will be recognized? Assume the interrupts are enabled and are not masked.

2. Suppose it is required to disable all the other interrupts except the GPIP interrupts for both controllers. In addition, GPIP interrupts 14-10 should be masked out. What words should be written into the interrupt enable and mask registers?

3. If the upper four bits of the vector register for MFP 1 are loaded with \$4, what vector number is supplied to the processor by MFP 1 for GPIP interrupt 16?

**1.** Interrupt recognition: MFP 1 is of higher priority than MFP 2 in the daisy chain.

2. Disabling and masking of interrupts: Refer to the bit map of the IERA/IERB (Fig-

To enable all the GPIP interrupts, disable the others, and additionally mask the I4-I0 interrupts, the bit patterns should be written as follows:

 b7
 b6
 b5
 b4
 b3
 b2
 b1
 b0
 register

 1
 1
 0
 0
 0
 0
 0
 0
 into IERA

 1
 1
 0
 0
 1
 1
 1
 into IERB

 1
 1
 0
 0
 0
 0
 0
 into IMRA

 1
 0
 0
 0
 0
 0
 0
 into IMRA

3. Vector number for 16: Refer to Figure 9.2. The channel priority number for 16 is 1110 =\$E. This will be loaded into the lower four bits of its vector register by MFP 1. The upper four bits are written by the user to be \$4 = 0100. Thus, the vector for the 16 interrupt corresponds to

### 0 1 0 0 1 1 1 0 = \$4E

### 9.2 INTERRUPT-DRIVEN SYSTEM APPLICATIONS

As we already know, the interrupt is a convenient means by which to obtain the attention of the processor. We will now emphasize this concept by describing practical applications involving the interrupt-driven gain controllers, DRAM systems, and dataacquisition systems.

### Interrupt-Driven Gain Controller

Figure 9.5 illustrates a digital gain-controller system. The 68901 MFP discussed earlier is used as an interrupt controller. The GPIP drives a summing amplifier-type D/A (digital-to-analog) converter. The D/A converter, in turn, drives a power amplifier and a DC motor.<sup>4</sup>

The internal B timer of the MFP is used to generate a timed interrupt to the processor. The  $\overline{IRQ}$  output from the MFP drives level 1 of the interrupt ( $\overline{IRQ1}$ ) of the 68000 processor through the encoder device. Each time the timer is decremented to zero from a preloaded value, an interrupt is generated by the timer. The 68901 routes that interrupt to the processor as  $\overline{IRQ1}$ .

When the processor recognizes this interrupt, it generates a higher gain digital word on the GPIP output, up to the maximum allowed. The processor increases the gain from a minimum to a maximum value and restarts the gain process. This has the effect of increasing the motor speed to a maximum at regular time intervals, reducing the speed to a minimum, and then starting the process again. In industry, such systems are used to control conveyer belts.

We will now discuss the design details by means of an example problem.



FIGURE 9.5 The 68000-based interrupt-driven gain controller system (Example 9.2).

### Example 9.2 Interrupt-driven gain controller

For the system of Figure 9.5, the MFP occupies the memory map starting at base address \$040000 (GPIP at \$040001. . .). Develop (1) the operating hardware and (2) the software so that the motor speed increases to the next value up in 20-second intervals.

### Solution

- 1. Hardware: The hardware of Figure 9.5 is self-contained. If increased drive capability is required, additional power amplifier stages can be incorporated. The XTL1 clock input for the MFP is driven by a 2.456-KHz oscillator. The low-pass filter (LPF) effectively removes any switching transients from the D/A converter.
- 2. Software: The software initializes the appropriate MFP interrupt and timer-related registers (refer to Sections 8.4, 8.5, and 9.1). It increases the digital gain word to the next value up on each timer interrupt occurrence. This digital word is then output to

the GPIP port. (The word is converted to an analog voltage and drives the motor at the appropriate speed.)

Figure 9.6 details the MFP initialization process. The unused registers are loaded with the inactive words on system reset. The flowchart and the 68000 program listings for the interrupt-driven gain controller are presented in Figures 9.7 and 9.8, respectively.





Between lines 6 to 23 in the listings, all the MFP registers used in the software are declared and initialized. Timer B has an internal priority of 8 (refer to Section 9.1), which presents an effective device interrupt vector of \$40 + \$08 = \$48 to the processor. This refers to a vector address of

 $4 \times \$48 = \$120$ 

FIGURE 9.7 Flowchart for the interrupt-driven gain controller using the 68901 MFP with the 68000.



At line 25, the interrupt service routine address of \$2000 is loaded into this vector address location of \$120.

At lines 28 and 29, the timer data and control registers (TBDR and TBCR) are loaded with \$F5 and \$07. This enables timer B with a prescale factor of 200. Timer B counts down and generates an interrupt when it is decremented to zero from the preset value of \$F5 (= 245). With a 2.45-KHz XTL1 clock, this generates a 20second delay between successive interrupts as shown:

At lines 30 and 31, the system goes into a wait loop and waits for the above interrupt to occur.

### **Delay** = (prescale factor) × (preset value) × (XTL1 period) $= (200) \times (245) \times (1/2.45 \text{ KHz}) = 20 \text{ seconds}$

|               |                        |      |      |           |                  |           |                          |                                    | _ |
|---------------|------------------------|------|------|-----------|------------------|-----------|--------------------------|------------------------------------|---|
|               | DDR                    |      |      |           |                  |           |                          |                                    |   |
| 1.2           |                        |      |      |           | int co<br>FIU 9/ |           | roller                   |                                    |   |
| E             |                        |      |      | ;         |                  | 1100      | ,                        |                                    |   |
| 4             |                        |      |      | -         | OPT              |           | A                        |                                    |   |
| 5             |                        |      |      |           | ORG              |           | \$1000                   | ~                                  |   |
| 6<br>7 0004   | 0000                   |      |      |           | 68901<br>ASE     | reg       | jister dec<br>EQU        | larations<br>\$040000              |   |
| 8 0004        |                        |      |      |           | ASE<br>PIP       |           | EQU                      | \$040000<br>BASE+\$01              |   |
| 9 0004        |                        |      |      |           | DR               |           | EQU                      | BASE+\$05                          |   |
| 10 0004       |                        |      |      |           | ERA              |           | EQU                      | BASE+\$07                          |   |
| 11 0004       |                        |      |      |           | MRA              |           | EQU                      | BASE+\$13                          |   |
| 12 0004       |                        |      |      | V )<br>۳1 | R<br>BCR         |           | EQU                      | BASE+\$17<br>BASE+\$1B             |   |
| 14 0004       |                        |      |      |           | BDR              |           | EQU<br>EQU               | BASE+\$21                          |   |
| 15            |                        |      |      | ;         | initia           | lliz      | ze MFP: GP               | IP is output                       |   |
| 16            |                        |      |      |           | Timer            | Вj        | interrupt                | enabled                            |   |
|               | 1000 1380              | 9055 | 2007 | ;;        | initia<br>∽ Mour | 112       | ze DO with               | speed word                         |   |
| 1 10 0000     | 11000 13FC<br>0005     |      | 0004 | Siar.     |                  | 1.0       | #\$ <b>"「,</b> 」」        |                                    |   |
| 19 0000       | 11008 103C             | 0000 |      |           | MOVE.            | В         | #\$00,D0                 | ;MINIMUM SPEED                     |   |
| 20 0000       | 100C 13C0              | 0004 | 0001 |           | MOVE.            | В         | DO,GPIP                  |                                    |   |
| 21 0000       | 11012 08F9<br>0007     |      | 0004 |           | BSET.            | В         | #Ó,IERA                  |                                    |   |
|               | 101A 08F9              |      | 0004 |           | BSET.            | B         | #C,IMRA                  |                                    |   |
|               | 0013                   |      |      |           | 0001.            | 5         | #U/LUMA                  |                                    |   |
| 0000 ES       | 1022 13FC              |      | 0004 |           | MOVE.            | В         | #\$40,VR                 |                                    |   |
| 24            | 0017                   |      |      |           | ·intor           |           | + addrogg                | 00000 ista 0100                    |   |
|               | 102A 21FC              | 0000 | 2000 |           |                  |           | #\$2000,\$1              | \$2000 into \$120<br>20            |   |
|               | 0150                   |      | LUUL |           | 1.0.2.           |           | ##C000;+2                |                                    |   |
|               | 1032 4071              |      |      |           | NOP              |           |                          |                                    |   |
| 27<br>28 0000 | 1034 13FC              | OORC | 0007 | -         | set 1            | 'im∈<br>¤ | er B for 2<br>#\$F5,TBDR | O seconds                          |   |
|               | 1200<br>1200<br>1200   |      | 0004 |           | nove.            | ъ         | #\$12,100M               |                                    |   |
| 29 0000       |                        |      | 0004 |           | MOVE.            | В         | #\$07,TBCR               | ;start tímer                       |   |
|               | 001.8                  |      |      |           |                  |           |                          |                                    | į |
|               | 1044 60FE<br>1046 60FC |      |      | WAIT      | BRA.S            |           | WAIT                     | ;wait for                          |   |
| 1 35 0000     | 1046 BUIC              |      |      |           | BRA.S<br>ORG     |           | WAIT<br>\$2000 tin       | ;interrupt loop<br>terrupt routine |   |
|               | 2000 13FC              | 0000 | 0004 |           | MOVE.            | B         | #\$00.TBCR               | ;disable timer                     |   |
|               | 001B                   |      |      |           |                  |           |                          |                                    |   |
|               | 2008 8200              |      | 9901 |           | ADDQ.            | B         | #\$01,D0<br>D0,GPIP      | .;next gain word                   |   |
|               | 200A 13C0<br>2010 13FC |      |      |           | MOVE.<br>MOVE.   | в<br>R    | TRAC LEVE<br>TRAC LEVE   | ;output to GPIP<br>;20 sec timer   |   |
|               | 0021                   |      |      |           | ш <b>отн.</b>    | ъ         | ##£J <b>/</b> IDER       | ,EU SEC CIMEL                      |   |
| € 37 0000     | 2018 13FC              | 9007 | 0004 |           | MOVE.            | В         | #\$07,TBCR               | ;start timer                       |   |
|               | 001B                   |      |      |           | -                |           |                          |                                    |   |
|               | 2020 4071<br>2022 4073 |      |      |           | NÓP<br>RTE       |           |                          |                                    |   |
|               |                        |      |      |           | UTP              |           |                          |                                    |   |

FIGURE 9.8 Software listings for the interrupt-driven gain controller using the 68901 MFP (Example 9.2),

When the timer B interrupt is generated once every 20 seconds, the processor goes to the interrupt service routine between lines 32 and 39 (starting address \$2000). The interrupt service routine stops timer B by loading \$00 into the TBCR. It increments and outputs the digital gain word in the D0 register to the GPIP. It reloads the timer B data register with \$F5 and restarts it. The last RTE instruction returns the processor to the wait loop.

The timer B interrupt is communicated to the processor as a level 1 interrupt. The processor interrupt mask level in the system byte should be initialized to zero for recognizing a level 1 interrupt. With few modifications to the preceding software, it is possible to obtain a different result, as we will see in the following example.

Example 9.3 Modified interrupt-driven gain controller. Modify the software in Figure 9.8 so that the gain will not be increased if it is already at the allowed maximum.

### Solution

33 to 39 should be modified as shown:

| FINAL | MOVE.B<br>CMP.B<br>BEQ.S<br>ADDQ.B<br>MOVE.B<br>MOVE.B<br>MOVE.B<br>NOP<br>RTE | #\$DO,TBCR<br>#\$FF,DO<br>FINAL<br>#\$01,DO<br>DO,GPIP<br>#\$F5,TBDR<br>#\$D7,TBCR |
|-------|--------------------------------------------------------------------------------|------------------------------------------------------------------------------------|
|-------|--------------------------------------------------------------------------------|------------------------------------------------------------------------------------|

It should be noted that when the system reaches the maximum gain condition, it stays at that condition.

### **Dynamic Random Access Memory (DRAM) Interface**

Because of their higher density, DRAMs are fast replacing the static RAMs in large memory systems. DRAMs store binary information in the form of charge on MOS transistor cells. These cells have to be refreshed (rewritten) periodically, so that the charge will not decay and the information will not be lost. The typical refresh time for a mem-

The maximum allowed gain word is \$FF in the D0 register. The D0 register should only be incremented if its byte content is less than \$FF. The interrupt routine between lines

```
;disable timer B
;compare DD with $FF
; if equal branch to final inst
; if not increment DU by 1
;output new gain word to GPIP
;set timer to 20 seconds
;start timer B
;return (to wait loop)
```



FIGURE 9.9 Interrupt-driven DRAM interface to the 68000.

ory cell is 2 milliseconds. This refresh activity can be easily controlled with the help of interrupts and software techniques.<sup>5,6</sup>

A 1-megabyte DRAM device (such as the Motorola MCM511000) is organized as 512 rows by 2,048 columns. During the first half of the bus cycle, the row address is presented to the DRAM and the /RAS (row address strobe) is activated. All 512 cells on that row present their information internally to sense amplifiers. During the second half of the bus cycle, the column address is presented and the /CAS (column address strobe) is activated. One out of the 2,048 columns is selected, and the appropriate data bit is thus addressed. For refreshing, it is sufficient that the row address be supplied and RAS activated.

Twenty address lines are required to access one out of a million locations. Externally, ten row address lines (A1-A10) and ten column address lines (A11-A20) are multiplexed to drive the ten address lines of the DRAM (pins A0-A9). Internally, these twenty effective address lines are adjusted in groups of nine and eleven (to address one out of 512 rows and one out of 2,048 columns).

Figure 9.9 illustrates a 1-megaword DRAM system interface with a 68000 processor, occupying the range between \$200000 and \$3FFFFF. The 68901 is used as an interrupt controller to generate a nonmaskable interrupt (level 7), once every 2 milliseconds. The processor recognizes this interrupt and executes 512 sequential NOP instructions contained in system ROM or EPROM. For the system shown, RAS is generated while the address lines A1-A9 from the 68000 change in sequence. This has the effect of refreshing the 512 rows (of all the 16 DRAM devices) in sequence. The DRAM is selected only when the /CSDRAM and /CAS signals are generated. This happens only when the locations in the DRAM are addressed.

If the DRAM is not refreshed within 2-millisecond intervals, the information may be lost. The highest priority interrupt is used (in this case, interrupt level 7) so that the processor will not mask it and will respond to the refresh operation.

In Figure 9.10, the DRAM refresh software listings are given. During the system initialization (reset routine), the DRAM module is called as a subroutine to initialize the interrupt controller (in this case, the 68901 MFP). (Refer to Chapter 8 for a description of the MFP/68000 interface.) Timer A, with an internal interrupt priority of \$D, is used in this application to generate a 2-millisecond delay.

Between lines 6 and 11, the MFP registers required for this application are declared. At line 14 the vector register of the MFP is loaded with \$40. When timer A generates an interrupt, the corresponding vector number is

### 40 + priority of timer A = 40 + D = 40

The corresponding exception vector location is

### $4 \times \text{vector number} = 4 \times \$4D = \$134$

At line 15, this vector location is loaded with the starting address of the interrupt service routine (INTR module).

```
LINE ADDR
                               ;ram.src 3/6/89
 1.
                               ;DRAM software refresh
 5
                                   OPT
                                            $1300
                                   ORG
                               ;68901 register declarations
                                                    $040000
                               BASE
                                            EOU
 6 00040000
                                                    BASE+$07
 7 00040007
                               IERA
                                            EQU
                                                    BASE+$13
 8 00040013
                               IMRA
                                            EQU
                                            EQU
                                                    BASE+$17
                               ٧R
 9 00040017
                                            EÕU
                                                    BASE+$19
                               TACR
10 00040019
                                                    BASE+$1F
                               TADR
                                            EOU
11 0004001F
                                                    $4E71
12 00004E71
                               NOP
                                            EQU
                               ;initialize 68901 for refresh
13
                              DRAM MOVE.B #$40,VR
14 00001300 13FC 0040 0004
            0017
                                   MOVE.L #INTR,$134
15 00001308 21FC 0000 1336
            0134 4E71
                               ;enable timer A interrupt
16
                                   BSET.B #5,IERA
17 00001312 08F9 0005 0004
            0007
18 0000131A 08F9 0005 0004
                                   BSET.B #S,IMRA
            0013
                               :timer A for 2 milliseconds
1.9
20 0001322 13FC 0031 0004
                                   MOVE.B #$31, TADR
             001F
21 0000132A 13FC 0006 0004
                                   MOVE.B #$06,TACR
            0019
22 00001332 4871
                                    NOP
                                   RTS
23 00001334 4E75
                                ; interrupt routine corresponds
24
25
                                ;to 512 locations of NOP codes
26 00001336 4871 4871
                               INTR DCB.W
                                                    512,NOP
                                    RTE
27 00001736 4873
                                   END
28 00001738
ASSEMBLER ERRORS =
                       0
```

FIGURE 9.10 Listings for the DRAM refresh software.

Between lines 17 and 22, the timer A interrupt is enabled and the timer A data and control registers are conditioned to generate an interrupt every 2 milliseconds. At line 25, the subroutine returns to the calling program.

The interrupt routine INTR starts at line 26. The NOP codes are sequentially arranged by means of the DCB.W 512,NOP assembler statement. When interrupt 7 occurs, these 512 NOPs are executed and the program returns to the interrupted program by means of the RTE instruction at line 27.

The following example problem provides a review of the interrupt controller and the DRAM implementation.

### Example 9.4 Interrupt-driven DRAM implementation. Consider the DRAM system and software of Figures 9.9 and 9.10.

- 1. Specify the relative timing of the RAS, MUX, CAS, and DTACK signal generation.
- 2. Specify how timer A is configured to generate an interrupt once every 2 milliseconds.
- 3. What percentage of processor time is taken for refresh?

### Solution

- 1. RAS, MUX, and  $\overline{CAS}$ :  $\overline{AS}$  is generated each time a bus cycle is initiated.  $\overline{RAS}$  is generated one CX0 (16 MHz) clock period after the AS signal. RAS latches the row address on the DRAM pins.
- MUX is generated two CX0 clock periods after the  $\overline{\text{AS}}$  signal. This presents the column address to the DRAM pins.
- CAS is generated three CX0 clock periods after the AS if the CSDRAM signal is activated. CAS latches the column address on the DRAM pins; the DRAM is selected only after  $\overline{CAS}$ .

 $\overrightarrow{\text{DTACK}}$  is generated four CX0 clock periods after the  $\overrightarrow{\text{AS}}$  signal. This is a proper timing sequence for data transfers.

- 2. Timer A interrupt: Bit 5 of the interrupt enable and interrupt mask registers (IERA and IMRA) is set to 1, enabling the timer A interrupt. When the timer counts down to zero from the preloaded number, an interrupt is generated. Timer A is decremented by the XTL1 clock. The timing calculation is as follows:
  - TACR loaded with 6 = 100 prescale factor
  - TADR loaded with \$31 = 49

Thus,

## Timer A countdown period = $\frac{100 \times 49}{2.4596 \times 10^6}$ = 2 milliseconds

3. Percentage of processor time for refresh: Refresh time corresponds to executing 512 NOP instructions. Each NOP instruction takes four CX1 processor clock periods. The timing calculation is as follows:

CX1 8-MHz processor clock = 125 nanoseconds cycle time NOP execution time =  $4 \times 125 = 500$  nanoseconds = 0.5 microseconds 512 NOP execution time =  $512 \times 0.5 = 256$  microseconds

XTL1 crystal clock = 2.4596 MHz

These 512 NOPs have to be executed once every 2-millisecond refresh interval. Thus,



FIGURE 9.11 Interrupt-driven A/D and D/A interface to the 68000. (Courtesy of Laura Ruiz and José Zarut, FIU)

Software refresh eliminates the need for additional hardware. In the preceding case, 12.8 percent of the processor time is devoted exclusively for refreshing 1-megaword of memory. Interrupt stacking and unstacking takes a few more clock cycles. In small-tomedium systems, such an arrangement is acceptable. However, for larger systems with more memory, hardware refresh is used with the help of memory management units.

## 9.3 THE INTERRUPT-DRIVEN DATA-ACQUISITION SYSTEM AND APPLICATIONS

The usefulness of any microprocessor-based system is greatly enhanced when it is interfaced with the analog word. This can be accomplished easily with the help of A/D (analogto-digital) and D/A (digital-to-analog) converters. The processor-to-A/D interface can be interrupt driven to make efficient use of the processor time.<sup>7</sup>

### The A/D and D/A Interface

Figure 9.11 illustrates a typical A/D and D/A interface to the 68000 microprocessor through the 68230 PI/T (refer to Chapter 7 for PI/T details). ADC 0816 is an 8-bit 16channel A/D converter device. By means of the select word DCBA, any one of the 16 input channels (VIN0-VIN15) can be selected. DCBA = 0000 selects VINO, and DCBA =1111 selects VIN15.

All of these analog voltages are signal conditioned and filtered before being applied to the A/D converter. Figure 9.12 illustrates a typical signal-conditioning system.

FIGURE 9.12 Analog signal conditioning for VIN inputs to the A/D converter.



A2: Voltage follower with unity gain. Its output is

A1: Noninverting amplifier

VX0 = (1 + R2/R1) VS0

R3 and C compose a low-pass filter with a radian cutoff frequency of

wo =  $1/(R3 \times C)$  radians sec.

VIN0 = [1/1 + jw/wo) [VX0]

where w is the radian frequency of VS0 input and j is the imaginary operator.

For low frequencies less than wo, VIN0 = VX0.

The signal input VSO is buffered by high-input impedance noninverting amplifier Al. The Al amplifier has an effective voltage gain of 1 + (R2/R1). VSO input should be in the range of 0 to 5 volts for this system. The R3-C network provides low-pass filter action to remove switching transients. The A2 amplifier is a voltage follower, the output (VINO) of which is applied as inputO (INO) to the A/D converter of Figure 9.11.

The A/D converter digitizes the applied analog input voltage VIN and produces a corresponding 8-bit digital word on its B1-B8 outputs. A 640-KHz clock drives the A/D converter. The converter is interfaced to port B of the 68230 PI/T. The H3 and H4 handshake lines control the A/D. A pulse from the microcomputer on the H4 line to the START input of the A/D converter starts the conversion of the selected VIN input.



FIGURE 9.13 The 68230 PI/T register initialization for the data-acquisition system.

When the conversion is complete, the A/D converter generates a pulse on its EOC (end of conversion). It is connected to the H3 handshake input of the 68230 which in turn, generates an interrupt to the processor on its PC5/\*IRQ line. In this application, /IRQ drives a level 2 interrupt (/INT2).

The DAC 0800 D/A converter is interfaced to port A of the 68230 PI/T as indicated. This 8-bit D/A converts the processed digital word on its B1-B8 inputs (sent by the processor on its port A) into a corresponding analog voltage VA. VA is filtered using the low-pass filter (LPF) amplifier to remove any step and switching transients and to provide a reconstructed analog voltage VO. The LPF has a cutoff frequency of 8 KHz, which is sufficient in most audio, control, and instrumentation systems.<sup>8</sup>

FIGURE 9.14 Flowchart for the 68000-based data-acquisition system (Example 9.5).



| LINE<br>1<br>2           | ADDR                  |              |      |      | LLEN 108<br>OPT A                                                                   |
|--------------------------|-----------------------|--------------|------|------|-------------------------------------------------------------------------------------|
| 3<br>4                   |                       |              |      |      | *<br>* ADC/DAC SYSTEM INTERFACE<br>*                                                |
| 5<br>6<br>7              |                       |              |      |      | * MOTOROLA 68000<br>* 2/7/ <b>87</b>                                                |
| 8<br>9                   |                       |              |      |      | *<br>* Laura Ruiz<br>*                                                              |
| 10<br>11<br>12 0(        | 0010001               |              |      | PGCR | ORG \$900<br>EOU \$010001 ; Port General                                            |
| 13<br>14 DI<br>15        | 0010003               |              |      |      | ; Control Register<br>EQU \$010003 ; Port Service<br>: Request Register             |
|                          | 0010005               |              |      |      | EQU \$010005 ; Port A Data<br>; Direction Register                                  |
| 18 DI<br>19              | 0010007               |              |      |      | EQU \$010007 ; Port B Data<br>; Direction Register<br>EOU \$01000B ; Port Interrupt |
| 21                       | 001000B<br>001000D    |              |      |      | EQU \$01000B ; Port Interrupt<br>; Vector Register<br>EQU \$01000D ; Port A Control |
| 23<br>24 0               | 001000F               |              |      |      | ; Register<br>EQU \$01000F ; Port B Control                                         |
| 25<br>26 0<br>27         | 0010011               |              |      | PADR | ; Register<br>EQU \$010011 ; Port A Data<br>; Register                              |
|                          | 0010013               |              |      | PBDR | EQU \$010013 ; Port B Data<br>; Register                                            |
| 30<br>31 0<br>32 0<br>33 | 00000000<br>100000000 | 4280<br>247C | 0000 | 5700 | *<br>CLR.L DO<br>MOVEA.L #\$2100,A2 ;memory block<br>;to store data                 |
| 34 O<br>35               | 8020000               | 163C         | OOFF |      | MOVE.B #\$FF,D3 ;ctr to store 256<br>; bytes in memory                              |
| 36<br>37                 |                       |              |      |      | *<br>* Initializing registers<br>*                                                  |
| 38<br>39 C               | 3000000C              | 13FC<br>0007 | 0000 | 0001 | MOVE.B #\$DD, PBDDR ;port B: input                                                  |
|                          | 0000914               | 13FC<br>0005 |      |      |                                                                                     |
| 41 C                     | 000091C               |              | 005C | 0001 | MOVE.B #\$2C,PGCR ;mode OD,H34                                                      |

| 42<br>43 |      | 100924          | 4 131        | 20  | ÖOFA         | 0001 |               |        |
|----------|------|-----------------|--------------|-----|--------------|------|---------------|--------|
|          |      |                 | 000          | B   | UOFA         | 0001 |               |        |
| 44<br>45 |      | )5000(<br>50000 |              |     | 0000<br>0000 |      |               |        |
| 46       |      |                 |              |     |              | 6000 |               |        |
| 47       | 000  | DOADS           | 13F<br>000   |     | 001C         | 0001 |               |        |
| 48       | _    |                 |              | 3   |              |      | :             | e      |
| 49<br>50 | 000  | 00940           | 103          | 9 ( | 001          | 0013 |               |        |
| 51<br>52 |      |                 |              |     |              |      | ;             |        |
| ⊃c<br>53 | 000  | 00946           | 13F          | сı  | AEOL         | 0001 | ;<br>WAI      | т      |
| 54       |      |                 | 000          | F   |              |      |               | -      |
| 55       |      |                 |              |     |              |      | • • • • • • • |        |
| 56<br>57 |      | 0094E<br>00950  |              |     |              |      |               | 1      |
| 58<br>59 |      |                 |              |     |              |      | ;             |        |
| 60       |      |                 |              |     |              |      | ; ;           | (      |
| 61<br>62 | 000  | 02000           | 13F(         | с п | 038          | 0001 |               | (<br>1 |
| 1.7      |      | 32008           | 0001         | F   |              |      |               |        |
| 64       | 0000 | 3500E           | 14C          | 1   | 001          | 0013 |               | 1      |
| 65<br>66 | 0000 | 12010<br>12012  | 5343<br>4A03 |     |              |      |               | 2      |
| 67       | 0000 | 2014            | 6704         | 4   | E71          |      |               | E      |
| 68<br>69 | UUUL | 15079           | 4E73         |     |              | BA   | СК<br>*       | E      |
| 70<br>71 | 0000 | 701A            | 13E2<br>0011 |     | 001          | FI   | NAL<br>*      | Ľ      |
| 72       | 0000 | 02020           | 183C         | : 0 | 040          |      | *             | Μ      |
| 74       |      | 2024<br>85051   |              | _   | 001          | DE.  | LAY           | S<br>B |
| 75<br>76 | 0000 | A5051           | 0603         |     | 001          |      | *             | _      |
| 77       | 0000 | 505B            | 0003         | 0   | ]FF          |      |               | A<br>C |
|          |      | 2032            | 66E6         |     |              |      |               | B<br>B |
| 79       | 0000 | 5036            | 2226         |     |              |      |               | E      |
| i        | ÁSSE | MBLER           | ERR          | ORS | 5 =          | 0    |               |        |
| <br>     |      |                 |              |     |              |      |               |        |
|          |      |                 |              |     |              |      |               |        |

FIGURE 9.15 Software for the 68000-based data-acquisition system (Example 9.5). (Courtesy of Laura Ruiz, FIU).

FIGURE 9.15 Continued.

enabled high; MOVE.B #\$FA,PIVR ;vector int MOVEA.L #\$3E8,A1;vector add(FA\*4) MOVE.L #\$00002000,(A1);interrupt ;routine address MOVE.B #\$1C,PSRR ;PIRQ,PIACK enable H3 at highest priority MOVE.B PBDR,DO; H4 first pulse. Wait for interrupt from ADC when conversion is ready T MOVE.B #\$3A,PBCR ;00 submode and pulsed input handshake mode. H3 enabled. BRA WAIT BRA WAIT Interrupt routine : read port B; output to port A ORG \$2000 MOVE.B #\$38,PBCR; H3 disabled MOVE.B PBDR,DO ; read input MOVE.B DO,(A2)+ ;store in memory SUBQ #1,D3 ;decrement ctr TST.B DB ;check if done BEQ FINAL RTE ; return from interrupt MOVE.B -(A2), PADR; data to port A MOVE.B #\$40,D4 ;delay SUBI.B #1,D4 BNE DELAY ADDI.B #1,D3 CMPI.B #\$FF,D3 ;increment ctr ;check if done BNE FINAL ;send more data ;if 256 data sent, ;start back ADC BRA BACK END

### A Typical Data-Acquisition System

With appropriate software, the A/D and D/A system of Figures 9.11 and 9.12 can be integrated into a useful data-acquisition and instrumentation system. For the 68000based system under consideration, the 68230 PI/T resides at the address map between \$010001 and \$01003F. Port A is configured as an 8-bit output port to drive the D/A converter. Port B is configured as an 8-bit input port to accept the A/D data.

The handshake signals H3 and H4 are configured for pulse handshake on port B. A pulse will be generated on H4 whenever port B is accessed. This pulse starts the A/D conversion. When the A/D conversion is complete, H3 input will be activated by the A/D converter. This interrupts the processor, which, in turn, reads the digitized data on port B. This interrupt handshake between the 68230 PI/T and the 68000 is accomplished by configuring the PC5 (port C, pin 5) as an /IRQ to the processor and the PC6 (port C, pin 6) as the IACK to the 68230 (refer to Figure 9.11).

The user vector method is employed in this application to provide the interrupt vector to the processor. The DCBA switches are set to 0000 to select VINO as the analog input. Figure 9.13 (p. 254) illustrates the 68230 initialization required for this application.

The flowchart and operating listings for a 68000-based computer using the preceding data-acquisition system are given in Figures 9.14 (p. 255) and 9.15 (pp. 256-257). The software configures the 68230 PI/T ports and the CPU registers. The interrupt routine reads the A/D data (from port B), stores up to 256 data bytes, and outputs the stored data in the reverse order to the D/A (on port A). Finally, the software loops back for the next digitization.

We will now analyze the software and the system response with the help of an example problem.

### Example 9.5 Data-acquisition system.

Consider the data-acquisition system hardware and software of Figures 9.11 through 9.15.

- 1. Analyze the software. Where is the A/D data stored?
- 2. Where does the interrupt service routine start?
- 3. VINO is as shown in the following diagram. Plot reconstructed VO output to scale.



### Solution

with \$00000000, \$2100, and \$FF, respectively.

Between lines 38 and 43, the PI/T registers are initialized according to Figure 9.13. At lines 44 and 48, \$00002000 is stored at vector location 3E8 and port C is configured for interrupt activity (PC5 is an /IRQ and PC6 is an /IACK). Accessing port B (at line 49) generates the first H4 pulse to start the A/D process. Between lines 53 and 56, the processor enables the H3 interrupt and goes into a wait loop-waiting for the interrupt to occur at the end of the conversion.

On occurrence of the H3-activated interrupt, the processor fetches the interrupt routine address (\$00002000) from the vector location \$3E8 and starts the interrupt exception routine (line 62). At line 62, the H3 interrupt is disabled so that the processor will not be reinterrupted by the A/D while it is servicing the interrupt that already has been recognized.

At lines 63 and 64, the processor reads the A/D byte from port B and stores it in the memory in an ascending order. If 256 bytes of the A/D data are stored, the program branches to the final module (lines 65 to 67). Otherwise, the program returns to the wait loop by means of the RTE instruction at line 68.

The final module is contained between lines 70 and 79. It outputs 256 bytes of the stored A/D data in the memory to the D/A converter through port A in a descending order. The delay loop (lines 72 to 74) provides delay between successive D/A samples. After all 256 samples are output, the program branches back to line 68 and the RTF instruction at line 68 returns the program to the wait loop.

**2.** Interrupt service routine: This routine starts at location \$00002000 (line 62).

3. VO waveform: The digitized and stored data (256 bytes) are output to the D/A converter in the reverse order, with delay between the samples (lines 70 to 79 of the software). Thus, the reconstructed VO analog signal looks backward, as diagrammed, when compared to the corresponding VINO input.



1. Software analysis: Between lines 12 and 28, all the PI/T registers used in this application are defined. Between lines 31 and 36, registers DO, A2, and D3 are initialized

Interrupt-driven data-acquisition systems are extremely useful in industrial applications. Data processing may be more involved than a signal reversal, and data storage well over 256 bytes. The general hardware and software concepts of the data-acquisition and the A/D and D/A interface schemes remain the same, however.

We will now present another example problem in which the importance of D/A conversions and associated waveform generation are emphasized.

### Example 9.6 Waveform generation using D/A.

With reference to Example 9.5, suppose it is necessary to generate a triangular waveform at the output of the D/A converter (connected to port A PADR). Assume all the initialization conditions of Example 9.5.

- 1. Develop the operating software.
- 2. How is the frequency of the waveform changed?

### Solution

- **1. Operating software:** The flowchart and the 68000-based program listings to accomplish the task are given in Figure 9.16. The DO register is used as the count register. It is incremented and output to port A (with a delay) if the count is between \$00 and \$FF. This provides a positive-going ramp at the output of the D/A. If the DO register equals \$FF while it is being incremented, it is then decremented and is output to port A (with a delay). This provides a negative-going ramp at the output of the D/A. The positive- and negative-going ramps generated in sequence provide the required triangular waveform.
- 2. Changing the frequency: The frequency can be changed by changing the delay counter parameter in the instruction MOVE.W #\$40,D4. If the number \$40 is increased, the frequency proportionally decreases.

In the preceding example, the maximum frequency will be obtained if the delay routine is deleted.

### 9.4 DIRECT MEMORY ACCESS (DMA) CONSIDERATIONS

DMA techniques help accomplish high-speed data transfers between memory and memory, memory and I/O, and vice versa. The DMA operations are performed with the help of DMA controller devices. These controllers obtain the address, data, and the control buses from the processor and implement the DMA transfers. During the DMA transfers, the processor is logically disconnected from the buses.

### General Architecture of the DMA Controllers

Figure 9.17 illustrates a typical DMA system organization. The I/O device requests the controller for DMA operation. The DMA controller, in turn, requests the processor, ob-

FIGURE 9.16 (a) Flowchart and (b) 68000 assembly program listings for the triangular waveform generation (Example 9.6).







; all the initialization conditions of previous example ; are used in this software #\$00,D0 #\$01,D0 ;increment D0 DELAY DO, PADR ;output D0 to port A #\$FF.DO DOWN ; if DO = \$FF branch to DOWN ŪÞ #\$01,D0 ;DECREMENT DO DELAY D0,PADR ;output D0 to port A #\$00,D0 ŪΡ ; if DO = \$00 branch to UP DOWN #\$40,⊡4 delay counter initialize; D4, LOOP delay loop;

(b)



FIGURE 9.17 General concept and architecture for the DMA system.

tains the buses, and performs the DMA data transfers between memory and memory, memory and I/O, and vice versa.<sup>9,10</sup>

Figure 9.18 illustrates the typical DMA bus request timing for the 68000 family of processors. To request the buses, the DMA controller activates the  $\overline{BR}$  (bus request) signal to the processor. The processor recognizes this request and activates the  $\overline{BG}$  (bus



FIGURE 9.18 DMA bus request, bus grant, and acknowledge timing. (Courtesy of Motorola Inc.)

grant) signal to the controller. The controller, in turn, sends the BGACK (bus grant acknowledge) signal to the processor and takes control of the buses. The DMA controller is the bus master until the /BGACK is deactivated. The controller drives the address and control buses and performs the DMA operations. The processor regains control of the buses after the /BGACK is deactivated.

### The 68440 and 68450 DMA Controllers

The 68440 and 68450 are industry standard DMA controller devices belonging to the 68000 family. The 68440 has two DMA channels, while the 68450 has four DMA channels. These devices are pin compatible with one another and are contained in a 64-pin DIP or a 68-pin grid-array package. They are fabricated with HMOS technology. The devices are similar with respect to internal architecture. Both have signals similar to those of the 68000 processor.

Figure 9.19 illustrates the signal organization for the 68440/450 devices. The higher order address bus (A8-A23) is multiplexed with the 16-bit data bus (D0-D15). These buses are demultiplexed by external logic and are connected to the 68000 system bus. There are two modes of operation for DMA controllers: the CPU mode and the DMA mode.

In the **CPU mode of operation,** the processor is the bus master. The DMA controller resembles an external device. The control signals R/\*W, /LDS, /UDS, and /AS behave as inputs to the DMA controller. The DTACK signal behaves as an output. The processor effectively writes or reads information from the DMA controller.

In the DMA **mode** of **operation**, the processor releases the control of the buses, and the DMA controller becomes the bus master. The aforementioned signals behave in a manner opposite to that described. The controller generates all the 68000-compatible signals appropriate for data transfers.

The multiplexer control signals control the demultiplex logic for the data and address buses to appropriately interface the 68000 system bus. The DMA controller communicates with the I/O systems via the device control signals /REQ, /ACK, /PCL, /DTC, and /DONE.

The DMA controller communicates with the processor via the bus arbitration signals /BR, /BG, and /BGACK, and via the interrupt signals /IRQ and /IACK.

Figure 9.20 illustrates the internal register structure of the 68440/68450-type DMA controllers. Each channel consists of 17 registers. In addition, each device has a general control register, GCR. Some of these registers are initialized by the processor to set up the DMA operation. Others present the status information to the processor. We will discuss the details of these registers in the following section.

### Modes of Operation of the DMA Controllers

When the controller is serving as the bus master, it is in the DMA mode of operation, performing the data transfers. This DMA mode allows for two distinct modes: the single-address mode and the dual-address mode.



FIGURE 9.19 Signal configuration for the 68440/450 DMA controller devices.

In the single-address mode, the data transfers are between the I/O and memory. The controller changes the memory address for successive transfers, but the I/O address remains the same. The I/O device is activated by the /ACK signal from the controller. The data transfer takes only one bus cycle.

In the **dual-address mode**, the transfers are between memory and memory. In this mode, the controller contains the source and the destination addresses in the MAR and DAR registers. Any external peripheral device has sequential address space similar to that of memory. The controller generates the source address and reads the source dperand into ansinternal temporary (register, TEMP, during the first bus cycle. It generates a current of the second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second s

further detail<sup>C0</sup>"<sup>C0</sup>"<sup>to</sup>llerS \*\* <sup>CompleX devkes; data books should be consulted for and alLaL"<sup>0</sup>" <sup>PreSCnt</sup>"</sup>

eX3mPle Problem t0 reViCW oMA COnCeptSt COntro,,erst

Channel 3

| #BITS | REGISTER                         |        |
|-------|----------------------------------|--------|
| 8     | general control register         | GCR    |
| 8     | device control register          | -<br>7 |
|       | device control register          | DCR    |
| 8     | operation control register       | OCR    |
| 8     | sequence control register        | SCR    |
| 8     | channel control register         | CHCR   |
| 8     | channel priority register        | CPR    |
| 8     | channel status register          | CSR    |
| 8     | channel error register           | CER    |
| 8     | normal interrupt vector register | NIVR   |
| 8     | error interrupt vector register  | EIVR   |
| 8     | memory function code register    | MFCR   |
| 8     | device function code register    | DFCR   |
| 8     | base function code register      | BFCR   |
| 16    | memory transfer counter          | MTCR   |
| 16    | base transfer counter            | BTCR   |
| 32    | memory address register          | MAR    |
| 32    | device address register          | DAR    |
| 32    | base address register            | BAR    |
|       |                                  |        |

between \$C0 and \$FF for 68450 only

FIGURE 9.20 Internal register architecture for the 68440/450.

# Example 9.7 DMA concepts and controller architecture.

Review the material covered in Section 9.4 to answer the questions that follow.

- 1. How many total registers are there for the 68440 and the 68450 devices? Explain.
- 2. Can all the channels operate simultaneously? Why or why not?
- 3. Specify the relative address locations of MAR and BAR for channel 2, in the case of the 68450 controller.
- 4. At what point does the DMA controller gain control of the buses? Under what conditions?

### Solution

1. Number of registers: Each channel has 17 registers. In addition, each device has the common GCR and a temporary register, TEMP, to hold data in the dual-address mode. Thus,

> the 68440 DDMA has  $2 \times 17 + GCR + TEMP = 36$  registers the 68450 QDMA has  $4 \times 17 + GCR + TEMP = 70$  registers

- 2. All channels: Only one channel becomes operational at any given time. This is because of the bus activity. Each channel can be individually initialized, however.
- 3. MAR and BAR (refer to Figure 9.20): For channel 2, the relative base address is \$80. As such,

(Note: To obtain the effective addresses, the chip select base address should be added.)

4. Control of the buses: After receiving the  $\overline{BGACK}$  from the DMA controller, the processor concludes the current bus cycle. The address, data, and control buses (specifically,  $R/\overline{W}$ ,  $\overline{LDS}$ ,  $\overline{UDS}$ , and  $\overline{AS}$ ) go into a high-impedance state. At that point, the DMA controller gains control of the buses.

# 9.5 THE DMA INTERFACE AND APPLICATIONS

Figure 9.21 illustrates a typical 68000/DMA/I-O interface. This is in the single-address mode. The I/O system is activated by the ACK signal from the DMA controller. DMA channel 0 is used in this application.



FIGURE 9.21 The 68000/DMA/I/O peripheral interface (Example 9.8).

# **DMA Sequence of Operations**

. . 1

The peripheral I/O system activates the REQ input to the DMA controller and initiates the DMA operation. The controller, in turn, activates the bus request  $(\overline{BR})$  signal to the processor. The processor responds back to the controller by activating the  $\overline{BG}$  output. The processor also completes the current bus cycle. The controller accepts the BR and sends the BGACK acknowledge signal to the processor. This signal is held low active by the controller until the DMA data transfers have been completed. When BGACK is

low, the data, address, and control buses of the 68000 remain in a high-impedance state (refer to Chapter 6, Section 6.1). The DMA controller takes control of these buses, becomes the bus master, and begins the data transfers.

Figure 9.22 specifies the typical sequence of events during single-address mode transfers from the I/O units to the system memory. Other types of DMA transfers follow a similar sequence of events.

|    | PROCESSOR                                                                                    | DMA CONTROLLER                                                                                                               | PERIPHERAL                               |
|----|----------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|
| 1, | Initializes DMA<br>controller in<br>response to external<br>signal, such as an               |                                                                                                                              |                                          |
| 2, | interrupt.                                                                                   |                                                                                                                              | Initiates REQ0<br>to DMA controller      |
| 3. |                                                                                              | Arbitrates and obtains<br>system bus:<br>BR to processor;<br>BG from processor;<br>BGACK to processor.                       |                                          |
| 4. | Goes into high-impedance<br>state for address and data<br>buses and negates control signals. | - BOACK to processor.                                                                                                        |                                          |
| 5. |                                                                                              | Assumes bus ownership:<br>Activates UAS, DBEN<br>DDIR signals.<br>Activates ACK to peripheral<br>during each read bus cycle. |                                          |
|    |                                                                                              | Activates memory<br>address, LDS,UDS,R/W<br>signals. Data written<br>into memory.                                            | Peripheral puts data<br>on the data bus. |
| 6. |                                                                                              | Increments MAR.<br>Decrements MTCR.                                                                                          |                                          |
| 7. |                                                                                              | Repeats steps 5 and 6<br>until MTCR = 0.                                                                                     |                                          |
| 8. |                                                                                              | DMA completed.<br>BGACK deactivated.<br>BUS control released.                                                                |                                          |
| 9. | Regains bus control<br>and continues the processing.                                         |                                                                                                                              |                                          |

FIGURE 9.22 Sequence of DMA operations in the single-address mode.

# **DMA Channel initialization**

The DMA controller must be initialized in accordance with the system application before any DMA activity takes place. For single-address transfers, the processor writes the starting address of the memory, the size and number of data operands to be transferred, the direction of transfer, and other such information into the appropriate registers of the DMA controller. For dual-address-mode transfers, the source and destination operand addresses are written into two separate registers.

After the first initialization, further reinitialization of the controller can be done internally by the controller, itself, if it is operated in the reload condition. We will now present an example problem to review the DMA sequence of operations and initialization schemes.

Example 9.8 DMA sequence and initialization. Suppose a 1-kiloword transfer of data to memory from a peripheral I/O port is required, using the DMA system of Figure 9.21. The DMA controller occupies the memory map between \$012000 and \$0120FF.

DMA channel 0 in the single-address mode is used. Memory for DMA transfers starts at \$00002000.

- 1. Using the 68440 DMA controller, illustrate the initialization of the DMA internal registers.
- 2. If the 68440 is replaced by a 68450 controller, will there be any change in the initialization? Why or why not?
- 3. Interrupt 7 (a nonmaskable interrupt) is being serviced when the DMA request comes to the processor from the controller. Will it be recognized? If so, specify the sequence of events.

# Solution

-

- 1. Initialization: Figure 9.23 illustrates the required initialization of the 68440 channel 0 registers (refer to Section 9.4 for the register map). The device control register (DCR) is initialized for a burst mode of transfer for word-sized operands. In addition, the I/O is activated by  $\overrightarrow{ACK}$ . The rest of the register initialization is selfexplanatory.
- 2. 68450 Initialization: For channels 0 and 1, the initialization sequence remains the same for the 68440 and 68450 devices, since these devices have the same memory map.
- 3. Interrupt and DMA: As soon as the DMA request comes, the processor must re-

spond, even if it is servicing an interrupt level 7. It issues the bus grant signal and



The other registers are not explicitly used, and the default conditions on reset are acceptable.

\$28

\$90

\$80

concludes the current bus cycle. It releases the control of the buses to the DMA controller on the occurrence of the BGACK signal.

Only one DMA channel can be serviced at a given time. Two such channels can be serviced (one at a time), if a 68440 controller is used. For four such channels, the 68450 controller should be used. The initialization scheme for each channel is similar to the scheme we have described. The DMA channels are prioritized by the controller.

# **DMA Software Considerations**

In DMA applications, the software basically initializes the DMA controller. When the peripheral is ready for DMA operation, it usually interrupts the processor. The processor recognizes this interrupt and initializes the DMA controller. Thereafter, the DMA request can occur at any time. The DMA request should not be allowed prior to, or during, the initialization of the DMA controller.

We will now introduce the software for DMA operations with the help of an example problem.

# **Example 9.9** Software for DMA operations. In the DMA system of Figure 9.21, interrupt 6 is activated by the peripheral I/O to initialize DMA channel 0. One-kiloword transfers, as specified in Example 9.8, are required.

| LINE ADDR                               |                   |      |              |                              | · · · · · · · · · · · · · · · · · · · |
|-----------------------------------------|-------------------|------|--------------|------------------------------|---------------------------------------|
| 1                                       |                   |      | DMA TNTTT    | ALIZATIONS                   |                                       |
| 2                                       |                   |      | ;9/9/88 F.   | T II                         |                                       |
| Ē                                       |                   |      | OPT A        | 1.01                         |                                       |
| 4                                       |                   |      | ORG \$1000   |                              |                                       |
| P 00015000                              |                   |      | ;68440/450   | registers defined            | 1                                     |
| 7 00012004                              |                   |      | DADE         | EQU \$012000                 | •                                     |
| 8 00012005                              |                   |      | DCR          | EQU \$012004                 |                                       |
| 9 00012007                              |                   |      | OCR          | EQU \$012005                 |                                       |
| 10 0001200A                             |                   |      | CHCR<br>MTCR | EQU \$012007                 |                                       |
| 11 0001200C                             |                   |      | MAR          | EQU \$01200A                 |                                       |
| 15 0007500L                             |                   |      | GCR          | EQU \$01200C<br>EQU \$01200C |                                       |
| 13 00001200                             |                   |      | INTL         |                              | -                                     |
| 14 00000078                             |                   |      | VECTOR       | EQU \$00001,20<br>EQU \$0078 | Ļ                                     |
| 15                                      |                   |      | ;            | 280 10010                    |                                       |
| 16<br>17 00001000                       | 34776 8           |      | ;initialize  | interrupt 5 vect             | searbbs TC                            |
| », попатоя <b>п</b>                     | 21rc 0000<br>0078 | 1500 | STRT MOVE.L  | #INTE,VECTOR                 | address                               |
| 18 00001008                             | uura              |      |              |                              |                                       |
| 19 0000100C                             | 4E71              |      | BRA          | TASK                         |                                       |
| 20 0000100E                             | 60F0              |      | NOP<br>BRA   | C TR D M                     |                                       |
| 21,                                     |                   |      |              | STRT<br>performing a task    |                                       |
| 55 00001010                             | 4E71              |      | TASK NOP     | veriorming a task            |                                       |
| 53 00001015                             | 5482              |      | ADDQ.L       | #\$02,D2                     |                                       |
| 24 00001014<br>25                       | GOFA              |      | BRA          | TASK                         |                                       |
| 26                                      |                   |      | ;Int #6 rou  | tine to initializ            | e DMA                                 |
| 27 00001200 ;                           | 1380 0000         |      | ORG          | \$880812800                  |                                       |
|                                         | 200F              | 0007 | MOVE.B       | #\$00,GCR                    |                                       |
| 59 00001508                             | 1976 DOGO.        | 0001 | MOUD         |                              |                                       |
| t i i i i i i i i i i i i i i i i i i i | 2005              |      | MOVE, B      | #\$90,0CR                    |                                       |
| 59 00001510 1                           | LIFC DOAD         | 0001 | MOVE.B       |                              |                                       |
| i                                       | 2007              |      | nove.b       | #\$80,CHCR                   | 1                                     |
| 30 00001218                             | 13FC 0400         | 8801 | MOVE.W       | #\$0400,MTCR                 |                                       |
| ŕ                                       | AUUS              |      |              | #\$64667MICK                 | 1                                     |
| 37 00007550 9                           | 23FC 0000         | 2000 | MOVE.L       | #\$00002000,MAR              |                                       |
| 35 00001559 7                           | 2001 200C         |      |              |                              |                                       |
| 33 0000122C 4                           | 1571<br>- CR      |      | NOP          |                              |                                       |
| 34;                                     | 15 ( <del>3</del> |      | RTE          |                              |                                       |
| 35;                                     |                   |      |              |                              |                                       |
| Э6;                                     |                   |      |              |                              |                                       |
| 32,0000155E                             |                   |      | END          |                              | Í                                     |
|                                         |                   |      | 1110         |                              | ļ                                     |
| ASSEMBLER                               | ERRORS =          | C    |              |                              |                                       |
|                                         |                   |      |              |                              |                                       |

FIGURE 9.24 DMA initialization software for the 68000/68440-450 system (Example 9.9).

- 1. Develop 68000-based operating software to initialize the DMA controller.
- 2. Compute the actual time of the DMA transfers, using the software developed. Consider the system (processor and controller) to be operational at 8 MHz.

### Solution

**1. DMA initialization software:** In Figure 9.24, the operating software using the 68000 is given. Between lines 6 and 14, the relevant channel 0 registers of the con troller (a 68440/450 device) are defined. At line 17, the interrupt 6 vectored address of \$00001200 is loaded into the exception table at location \$0078. This is the inter rupt 6 autovector location.

Between lines 18 and 24, the processor goes into a TASK routine. A task can be any processing activity the processor is involved in. For simplicity, we have chosen a three-instruction loop. The processor responds to the interrupt, if the interrupt is enabled, and appropriately initializes the DMA channel.

Between lines 25 and 33, the interrupt 6 service routine is contained. This routine initializes the DMA registers as specified in Example 9.8. After the initialization, when the DMA request occurs, the processor gives up the buses to the DMA controller to transfer the data, as outlined previously.

2. **Time for DMA transfers:** After the DMA channel has been set up, the transfer time is that of the 1-kiloword transfers. The DMA is set up for single-address transfers from the I/O peripheral to the system memory.

Each word transfer takes one bus cycle, which corresponds to four clock cycles. Thus, the timing is as follows:

Clock cycle time at 8 MHz = 0.125 microseconds Bus cycle time = 4 × 0.125 = 0.5 microseconds 1-kiloword DMA time = 1,024 × 0.5 = 512 microseconds.

Examples 9.8 and 9.9 involve the single-address mode of DMA operation. The dual-address mode of DMA operation is similar to the single-address mode; for the dual-address mode, however, each byte or word transfer takes two bus cycles for 68000-based systems.

## 9.6 SUMMARY

In this chapter we considered interrupt and DMA applications related to the 68000 microprocessor.

The external interrupts are properly encoded and applied to the /IPL2, /IPL1, and IPL0 inputs of the 68000 processor. A level 0 interrupt signifies that there is no pending interrupt. Interrupt levels 1 through 7 are set on priority, with level 2 higher than level 1, and so on. Level 7 is a nonmaskable interrupt (NMI).

These interrupts can be autovectored or device (user) vectored. In autovectoring, the processor goes to a fixed vector location. The autovectoring scheme is simple and is preferable when a fixed number of interrupt vectors is satisfactory for the application. The device-vectoring scheme is more involved, but it provides the scope for interrupt expansion. In device vectoring, the interrupting device supplies the corresponding vector number.

In order to increase the effective number of interrupts, a daisy-chain mechanism with a device-vectoring scheme is used. In the daisy chain, the device closest to the processor has the highest priority; the device farthest away has the lowest priority.

Interrupt processing is done in the supervisor mode. After stacking the program counter and the copied status register, the 68000 processor obtains the interrupt-vectored address from the appropriate vector location and executes the corresponding interrupt service routine.

We described the following interrupt-driven systems: the gain-controller system, the data-acquisition system, and the dynamic memory system. The discussions helped to provide insight into practical interrupt applications. The gain-controller application is widely used in industry; for example, in setting up proper motor speeds. In the data-acquisition system application, A/D and D/A interfaces to the processor are involved. The dynamic memory system application deals with interrupt-driven timing in memory system designs.

Whenever there is a requirement for high-speed data transfers, DMA (direct memory access) methods are used. In such methods, an external DMA controller obtains the control of the processor buses and implements data transfers without the intervention of the processor.

The industry standard 68440 and 68450 DMA controllers belonging to the 68000 family were introduced in this chapter. The 68440 is a dual-channel DMA controller. The 68450 is a quad-channel DMA controller. The devices are compatible with one another.

When there is a requirement for DMA-type data transfers, the DMA controller arbitrates and wins the system buses from the processor. The processor goes into a highimpedance condition for data and address buses and certain control signals. It goes into the inactive condition for other control signals. The DMA controller generates the required signals for data transfers and acts as the bus master.

DMA transfers can be between memory and I/O or between memory and memory. In the former case, they are single-address transfers. The DMA controller activates the peripheral at a single fixed address and the memory at a sequential address in the same bus cycle. Thus, the single-address mode is the fastest, and is well suited for DMA transfers between memory and I/O ports.

When data transfers are from memory to memory, they are dual-address transfers. The DMA controller reads the source operand (byte or word) into an internal temporary register during one bus cycle, and writes it into the destination location during the next bus cycle. Dual-address transfers take two bus cycles for byte or word transfers in 68000-based systems.

In all DMA applications, the DMA controller must be properly initialized by the processor before the actual operation. Otherwise, unpredictable results may occur.

# PROBLEMS

- 9.1 Assume that interrupt 5 is being serviced.
  - (a) Another level 5 interrupt occurs. Will it be recognized? Why or why not?
  - (b) Interrupt 7 occurs under the conditions of (a). Will it be recognized? Why or why not?
  - (c) Interrupt 7 is being serviced. Another level 7 interrupt occurs. Will it be recognized? Why or why not?
- 9.2 In ah 8-MHz 68000 system, /IRQ6 and /IRQ4 occur at the same time.
  - (a) Which will be recognized? In order to be recognized, specify the required duration of the interrupt.
  - (b) The /IRQ6 routine takes 32 microseconds; the /IRQ4 routine takes 64 microseconds. If they occur at the same time, specify the required duration of each in order to be recognized.
- **9.3** There are two methods of servicing interrupts: the autovector method and the user-vector method. Outline the advantages and disadvantages of each of these methods. Also specify applications particularly well suited to one or another of the methods.
- 9.4 Is the user stack involved in servicing interrupts? Explain.

(a) If subroutines are used in interrupt service routines, which stack is used? Why? (b) Which stack is used when an interrupt occurs during a user subroutine execution?

9.5 Assume IRQ6 is being serviced. IRQ7 occurs while the processor is fetching the op.code for the instruction

#### MOVE.L #\$734512A6,D1

- (a) How many T-states have to elapse before /IRQ7 is serviced? Explain.
- (b) Considering that the SSP is at S00003ABA at the time of the occurrence of /IRQ6, and the USP is at \$00004000, indicate the contents of the appropriate stack when /IRQ7 has been recognized.
- 9.6 The daisy chain is an accepted means of interrupt expansion. Outline the advantages and the disadvantages of the daisy-chain mechanism.
  - (a) In which applications is the daisy chain not the method of choice?
  - (b) In which applications is the daisy chain particularly useful?
- 9.7 In the daisy-chained system of Figure 9.4, suppose it is necessary for I/O system 2 to have higher priority. How should the system be redesigned?
- **9.8** For the system of Figure 9.4,
  - (a) how many external devices can be interfaced? Why?
  - (b) including the internal interrupt sources of the 68901 MFP, how many total interrupt requests can be handled? Why?

Note: Problems 9.9, 9.10, 9.13, 9.14, 9.16, 9.18, and 9.22 can be used as the basis for special projects involving hardware and software implementation.

9.9 Refer to Figures 9.5 and 9.8. Redesign the hardware and the software so that (a) the motor speed gradually increases to a maximum and stays there;

(b) the motor speed varies between a maximum and a minimum on the occurrence of each timer interrupt.

- 9.10 In a servo belt system, it is required to increase the motor speed to a maximum, have it remain stable for 10 units of time, and then gradually reduce it to minimum. The system is repetitive. Consider one unit of time as the occurrence of the timer interrupt. Design the hardware and the software needed to implement this system.
- 9.11 How many steps of gain variation are possible in the system of Figure 9.5 considering all the possible software features?
- 9.12 For the DRAM system of "Figure 9.9, specify what could happen if a lower level interrupt, such as level 1, were used for the refresh operation.
- 9.13 Suppose the DRAM system of Figure 9.9 has to be expanded to accommodate an additional 1 megabyte of DRAM starting at \$400000. Specify the hardware details.
- 9.14 Given the conditions of Problem 9.13, suppose it is necessary to modify the software of Figure 9.10 to refresh the 2 megawords of total DRAM. Redesign the software and implement it.
- 9.15 What is the maximum amount of DRAM that can be software refreshed using no more than 30 percent of processor time?
- 9.16 Redesign the data-acquisition system described in Section 9.3 so that
  - (a) the buffer to store the A/D data is 4 kilobytes; (b) the stored data is output to D/A with an attenuation of two units.
- 9.17 Additional signal shaping and processing are possible with data-acquisition system software. Redesign the software of Problem 9.16 so that the digital attenuation is 2 on even samples and 4 on odd samples.
- 9.18 The data-acquisition system can be easily converted into a digital voltmeter as shown in the following diagram. Digits 3 and 4 should display a voltage between 0.0 V and 9.9 V. Digit 2 should display + or -. Digit 1 should display a flashing 1 if there is an overload condition.



Design and implement the system.

- **9.19** Specify the complete address map for all four channels of the 68450 DMA controller. Why is there only one GCR for all four channels?
- **9.20** Draw the timing diagrams for the asynchronous bus signals when the DMA controller is in the following modes:
  - (a) the CPU mode, in which the controller resembles an I/O device to the processor;
  - (b) the DMA mode, in which the controller is the bus master and controls the data transfers.
- 9.21 With reference to the data books on 68440/450 controllers,
  - (a) discuss the bus arbitration scheme involving BR, BG, and BGACK for single-operand transfers and block transfers (assume 1-kiloword transfers);
  - (b) describe the handshake between the DMA controller and the peripheral device.
- 9.22 Redesign the system of Figure 9.21 using all-CMOS logic for minimum power operation.
- 9.23 Specify a sequence of operations similar to that of Figure 9.22 for
  - (a) dual-address transfers;
  - (b) port-to-port transfers.
- 9.24 Repeat Example 9.9 for the following transfers:
  - (a) 1 kiloword from memory to I/O;
  - (b) 10 kilowords from memory to I/O.
- **9.25** Repeat Problem 9.24 for memory-to-memory transfers with the DMA controller in the dual-address mode.
- **9.26** Compute the DMA timing assuming the conditions of Problem 9.24. Repeat the computation for the conditions of Problem 9.25.

# **ENDNOTES**

- 1. Davis, R. *Prioritized Individually Vectored Interrupts*. App. Note #819. Austin, TX: Motorola Microprocessor Group, 1981.
- 2. Motorola, Inc. *MC68901 MFP Data Book*. Phoenix, AZ: Motorola Technical Operations, 1984.
- Motorola, Inc. MTT8: 68000 Course Notes. Phoenix, AZ: Motorola Technical Operations, 1987.
- 4. Andrews, M. *Self-Guided Tour through the 68000*. Englewood Cliffs, NJ: Prentice-Hall, 1984.
- Motorola, Inc. MCM511000 Data Sheets. Phoenix, AZ: Motorola Semiconductor Group, 1988.
- 6. Wilcox, A. 68000 Microcomputer Systems. Englewood Cliffs, NJ: Prentice-Hall, 1987.
- 7. Miller, M.A. "Parallel Interfacing the 68000." Chap. 5 in *The 68000 Microprocessor: Architecture, Programming, and Applications.* Columbus, OH: Merrill, 1988.

"" FTOSIT \*'TM"""" Sy , , *m* D , , , *6m* <> "«TM<, , , *fP*, , , , , , , B, , , , , , ,

# CHAPTER

# 68010 and 68012 Architecture, **Organization, and Applications**

# Objectives

In this chapter we will study:

Virtual memory and virtual machine schemes The additional resources of the 68010 and 68012 Virtual memory implementation schemes Exception processing associated with virtual memory

# 10.0 INTRODUCTION

The **68010 virtual memory microprocessor** has more internal resources than the 68000 microprocessor. The additional resources are needed to implement designs based on virtual memory. Externally, the 68010 is pin compatible with the 68000 and can access 16 megabytes of logical memory."

The 68012 extended virtual memory microprocessor is similar to the 68010 internally, but has an extended address bus (A1-A29 and A31) that can address 2 gigabytes of logical memory.<sup>2</sup>

When there is a large logical memory space, but only limited physical memory space (due to hardware limitations), a virtual memory scheme is used. Such a scheme allows for effective implementation of a computer system in the logical address space while operating in the actual hardware physical memory space.

Study of the material in this chapter will help the reader understand the virtual memory concepts that are fundamental to the implementation of virtual memory system designs using the 68010 and 68012 microprocessors.

# 10.1 VIRTUAL MEMORY AND VIRTUAL MACHINE CONCEPTS

For most microcomputer systems, only a fraction of the memory and I/O resources of the processor are available. Virtual memory and virtual machine concepts allow the system to operate as if full system resources were available, even when only a fraction of them are physically represented. This enhances the scope of software and hardware development of the microcomputer systems.<sup>3</sup>

# Virtual Memory Schemes

Virtual memory gives the computer user the impression that the entire memory space is available for use. It is memory that is not present in the real-time physically accessible memory, although it is in the logical memory space of the processor and is contained in backup memory, such as disk. When the processor tries to access this memory, a memory-access fault occurs. The processor attempts to correct this fault by moving the contents from the virtual memory into the physical memory. The processor may move some of the physical memory contents into backup memory in order to create space for the virtual memory contents to be brought in. Figure 10.1 illustrates a virtual memory scheme.

## Virtual Machine Schemes

The extension of virtual memory concepts to cover other nonexistent hardware resources, such as the I/O, leads to virtual machine schemes. There may be several local operating systems under a governing operating system. Each of these local operating systems can access the I/O resources belonging to the others through the governing op-



FIGURE 10.1 Virtual memory concepts in computer systems.



All the I/O resources may be real or emulated (virtual).

FIGURE 10.2 Virtual machine scheme concepts.

erating system, as shown in Figure 10.2. These I/O resources may be real, or they may be emulated by the governing operating system.<sup>4</sup>

During emulation, the governing operating system mimics the corresponding I/O properties. However, the local operating system addressing these resources considers them to be part of its own system. Hence, the concept of the virtual machine: The local operating system looks like a user to the governing system, and like a governing operating system to the user.

We will now present an example problem to review what we have learned about virtual memory and the virtual machine.

## Example 10.1 Virtual memory and virtual machine concepts.

In a database management system using the 68010 processor, the memory map for physical memory and I/O is as follows:

System ROM/EPROM/RAM ⇒ \$000000 to \$00FFFF (64 kilobytes) System/User RAM ⇒ \$010000 to \$04FFFF (256 kilobytes) System I/O ⇒ \$100000 to \$1003FF (1,024 bytes)

Assume that appropriate virtual memory management software and hardware have been implemented.

1. The MOVE.W (A1),D1 instruction is executed with A1 = \$0C000E. Conceptualize the sequence of events. How is the virtual memory scheme implemented, if implementation is possible?

- 2. Now suppose AI =\$012345AE. Can the scheme be implemented?
- 3. Suppose it is necessary to implement an additional I/O system between I1A2300 and \$1A23FF. Conceptualize the implementation scheme for this virtual machine.

#### Solution

**1. Virtual memory implementation:** The 68010 processor has a 16-megabyte logical space between \$000000 and \$FFFFFF. Currently, the 68010 is accessing memory at \$0C000E. It is outside the physical memory, but is contained in the logical memory space. Therefore, the virtual memory scheme is possible.

In Figure 10.3, the conceptual events in the virtual memory implementation scheme are indicated. When the memory-access fault is detected, the fault correction software and the memory management hardware will move the virtual memory section (in which the current reference is made) into the real physical memory. The memory reference pointer (Al, in this case) will be readjusted to correspond to the remapped memory. Thus, the referenced memory will be made available to the processor for the data movement operations.

After the fault has been corrected, the processor resumes its earlier activity. The fault correction software is really bus error exception processing software (details to be discussed later).

- **2.** Memory access at \$012345AE for 68010- and 68012-based systems: The virtual memory scheme cannot be implemented for the 68010, since the location \$012345AE is beyond its logical space. However, in the case of the 68012 processor, the location is in the logical space and the virtual memory scheme can be implemented.
- **3. Virtual machine (I/O between \$1A2300 and \$1A23FF):** When a reference is made to this nonexistent I/O, the processor will implement the virtual memory schemes as



we have outlined, with additional emphasis on the emulation of the I/O device properties and associated operating systems.

In the preceding problem, mention was made of the virtual memory section from the backup memory being moved into the physical memory area. The functional details of this important virtual memory implementation concept are shown in the flowchart of Figure 10.4. A part of the physical memory is assigned as a memory buffer. This buffer is used for all the virtual memory transfers. A 64-kilobyte area between \$040000 and \$04FFFF is chosen as the memory buffer for our particular case.

When a virtual memory reference is made, the virtual memory implementation software checks whether the memory buffer area has been filled by an earlier virtual memory reference. If it has, the software moves the contents of the buffer into the corresponding backup memory. The software also readjusts any previously adjusted memory pointers to their original values.

When the buffer becomes available, the software moves the memory block containing the virtual memory reference from the backup memory into the buffer area. Also, the original pointer values are stored and adjusted to refer to the buffered area. After these adjustments, any related virtual memory reference will be accessed from the buffer area.





The flowchart for an A/D converter type of virtual machine emulation scheme is given in Figure 10.5. All the hardware signals are emulated by memory locations. A start pulse to the A/D converter starts the actual conversion process (refer to Chapter 9 on A/D conversions). This is accomplished by writing a 1 to a memory location (START) which mimics the A/D start input and the calling of an A/D subroutine.

The subroutine resets the start location and generates a delay corresponding to the actual conversion time of the A/D device. It then writes a data element, n (the initial value of n would be \$00), into the memory array designated to hold the A/D data. Finally, the software writes \$01 into the EOC (end-of-conversion) location which mimics the end-of-conversion pulse and returns the program to the calling routine.

It can be seen that the virtual machine emulation is software intensive and mimics hardware operations by writing into appropriate memory locations.

We will now present an example problem to review the actual implementation schemes of virtual memory and virtual machines.

#### **Example 10.2** Virtual memory!machine implementation schemes.

The memory buffer for a virtual memory implementation scheme is between \$040000 and \$04FFFF (64 kilobytes), as shown in Figure 10.4. A 64-kilobyte block (\$0000 to SFFFF) containing the virtual memory reference address will be moved from the backup memory into the buffer each time virtual memory implementation takes place. (Refer to Example 10.1 for the memory map of the 68010-based system.)

- 1. The MOVE.W (A1),D1 instruction is executed with Al = \$0C000E. Specify the actual memory block moved from the backup memory into the buffer memory.
- 2. What adjusted value will be in the memory pointer Al?
- 3. For an 8-bit A/D conversion emulation as a virtual machine, how many bytes of A/D data array are required for emulating a linear ramp signal?
- 4. Answer the preceding question for emulating a triangular wave.

#### Solution

- 1. Memory block moved into the virtual memory buffer: Memory pointer Al refers to an address \$0C000E which is not in the physical memory of the system, but which is in the logical memory space contained in the backup memory. Therefore, virtual memory implementation is possible. The memory block containing the virtual memory reference \$0C000E is between \$0C0000 and \$0CFFFF. Thus, memory block \$0C0000 to \$0CFFFF is moved into the buffer between \$040000 and \$04FFFF.
- 2. Adjusted memory pointer Al: The original Al pointer contents (\$0C000E) are stored in memory (possibly in the supervisor stack), and the pointer is adjusted to hold \$04000E. The pointer refers to the corresponding location in the memory buffer after the memory movement.
- 3. Linear ramp A/D emulation: The 8-bit linear ramp data are between \$00 and \$FF in increments of 1. This requires a 256-byte memory array. In addition, two byte locations are required to emulate the START and EOC signals, for a total of 258 locations. Thus, a 258-byte array is required.
- 4. Triangular wave A/D emulation: A triangular wave takes positive-going and negative-going ramps, for a total of 512 byte-sized data elements. Considering the START and EOC locations, the required memory array is 514 bytes.

The preceding concepts regarding virtual memory and virtual machine schemes apply to all processors having the proper resources. In the next few sections, we will describe these resources with reference to the 68010 and 68012 processors.

# 10.2 ARCHITECTURE OF THE 68010 AND 68012 MICROPROCESSORS

Figure 10.6 illustrates the general architecture and busing features of the 68010 and 68012 microprocessors. They contain all the resources of the 68000 microprocessor, with additional registers to handle the virtual memory and virtual machine schemes.

## Additional Register and Busing Resources

Internally, the 68010 and 68012 processors have a 32-bit vector base register (VBR). In addition, they have two 3-bit registers: the SFC (source function code) register and the DFC (destination function code) register. These registers help to implement the virtual memory management schemes.

VBR (Vector Base Register) This register contains a 32-bit base address, which is meant to relocate the exception vector table. This allows for a multioperating system in a multiuser environment. Each local operating system may have a different value written into the VBR. This leads to different exception tables for different local operating sys-



FIGURE 10.6 Architecture and additional resources for 68010/68012-type microprocessors.

tems. The default VBR value (on system reset) is \$00000000, which matches that of the 68000 exception table. This table corresponds to the governing operating system. The VBR can be accessed only in the supervisor mode (using the MOVEC instruction).

SFC and DFC (Source and Destination Function Code Registers) These registers contain information about the function codes (FC2, FC1, and FC0). They can be accessed in the supervisor mode using the MOVEC instruction. This provides easy ac-

| FC2 | FCI | FC0 | Cycle Type         |
|-----|-----|-----|--------------------|
| 0   | 0   | 0   | Reserved           |
| 0   | 0   | 1   | User data          |
| 0   | l   | 0   | User program       |
| 0   | l l | 1   | Reserved           |
| 1   | 0   | 0   | Reserved           |
| 1   | 0   | 1   | Supervisor data    |
| - 1 | 1   | 0   | Supervisor program |
| 1   | 1   | 1   | CPU space          |

FIGURE 10.7 The 68010/68012 function code table.

cess to the program or data space for virtual memory and virtual machine schemes. In Figure 10.7 the function code table for the 68010 and 68012 is given. The FC2 FC1 FC0 = 1.1 I condition is designated as the CPU space, which is further classified as follows:

FC2 FC1 FC0 = 
$$1 1 1$$
 and  $A4-A23 = 1 ... 1$ 

is the interrupt acknowledge cycle;

FC2 FC1 FC0 = 
$$111$$
 and  $A1-A23 = 0...0$ 

is the breakpoint cycle (details to be discussed later).

**Busing** The 68010 is pin compatible with the 68000 processor. Thus, the 68010 processor is contained in a 64-pin DIP or 68-pin grid-array package, as is the 68000. The 68012, however, has seven more address lines (A24-A29 and A31) to address 2 gigabytes of memory. An additional control line, RMC (read modify write control), is included for multiprocessor interfacing. To minimize noise, the 68012 has two additional ground pins. It is contained in a standard 84-pin grid-array package. It is not hardware compatible with the 68000/68010 processors; thus, hardware must be specially designed for the 68012.

**The Breakpoint (BKPT) Concept for the 68010 and 68012** When the BKPT #n (n = 0-7) instruction is executed, it results in illegal instruction exception processing. The function codes and the address bus can further be decoded to generate a hardware breakpoint condition for system debugging.

## Additional Instructions and Modified Instructions

The table of Figure 10.8 indicates additional instructions (new) and instructions that have been modified for the 68010 and 68012 virtual memory processors. The MOVEC, RTD, and the MOVES are new instructions and support the virtual memory implemen-

| Instruction                       | Syntax                         | Operation                                                                 | Type                            |  |
|-----------------------------------|--------------------------------|---------------------------------------------------------------------------|---------------------------------|--|
| Move control<br>register          | MOVEC Rn,Rc<br>MOVEC Rc,Rn     | Move long word between Rn (An or Dn)<br>and Rc (SFC,DFC,VBR,USP)          | Privilegeo<br>and new           |  |
| Return and<br>deallocate<br>stack | RTD #n                         | Return from subroutine and deallocate<br>#n bytes from stack (n is even)  | Normal<br>and new               |  |
| Move alternate<br>address space   | MOVES (ea),Rn<br>MOVES Rn,(ea) | Move between effective address and Rn<br>(SFC and DFC are preconditioned) | Privileged<br>and new           |  |
| Move status<br>register           | MOVE SR,(ca)                   | Move from status register to effective address                            | Modified<br>to be<br>privileged |  |

# FIGURE 10.8 Additional and modified instructions for the 68010/68012.

tation. The MOVE SR, <ea> instruction has been modified to be a privileged instruction. This facilitates the coexistence of the multiuser and local operating systems under a governing operating system. Local operating systems of users are prevented from accessing the status register. An attempt at such access causes an exception and takes the processor to the governing operating system (S bit = 1 in system bytes). The governing operating system controls the local operating systems, which are really in the user mode,

*Loop Mode* The 68010 and 68012 processors go into a loop mode of operation in executing a three-instruction loop involving the DBcc (decrement and branch on condition). The processor keeps the three instructions in the internal instruction queue and executes them until the loop condition is satisfied. This circumvents the external memory access bus cycles and greatly speeds up the loop operation. Data sheets for the 68010 and 68012 specify those instructions that are eligible for the loop mode of operation.<sup>5</sup>

The VBR is usually relocated for each local operating system. The stack is sometimes deallocated (for the governing operating system to input or retrieve information). Similarly, the SFC and DFC registers are reconditioned to address any memory space. These capabilities are unique to the 68010 and 68012. The rest of the software of these processors is similar to that of the 68000 processor.

We will now present an example problem to review the additional resources of the 68010 and 68012 processors and associated software considerations.

#### Example 10.3 68010112 additional resources and software.

In Figure 10.9, an initialization routine for the 68010 and 68012 processors is given. Assume that the TRAP #14 call, passing parameter 228 in the D7 register, returns the control to the governing operating system.

LINE ADDR 1;M68010.SRC 68010/12 :FIU 11/25/88 CHIP 68010 OPT A ORG \$1000 S; MOVE VECTOR TABLE TO NEW ADDRESS 00001000 4871 START NOP 0000 0000 3405 50010000 MOVEA.L #\$0,A0 ;AO=0 MOVEA.L #\$2000,A1 ;A1=\$2000 8 00001008 2270 0000 2000 0000100E 103C DOFF MOVE.B #\$FF,DO :DO=FF AGAIN 10 00001015 5508 MOVE.L (AO)+,(A1)+ 11 00001014 51C8 FFFC DBRA DD, AGAIN 12:INITIALIZE VBR AND TRAP #1 VECTOR AT \$84 13 00001018 247C 0000 2000 REINT MOVEA.L #\$2000,A2 14 0000101E 4E7B A801 A2,VBR :VBR=\$2000 MOVEC MOVE.L #\$3000,\$0084(A2) 15 00001022 2570 0000 3000 0084 16 0000102A 48B8 1036 4871 JSR FCODE 17 00001030 1E3C 00E4 MOVE.B #228,D7 ;TO SYSTEM 18 00001034 4E4E TRAP #1.4 19 00001036 267C 0000 0000 FCODE MOVEA.L #\$0,A3 20 0000103C 7207 MOVEQ #\$07,D1 21 0000103E 4E7B 1000 MOVEC D1,SFC ;SFC=111 22 00001042 0853 2000 MOVES.W (A3),D2 23 00001046 4E74 0008 RTD #\$8 24 0000104A 4E71 NOP 25: 26 0000104C END ASSEMBLER ERRORS = п SYMBOL TABLE 00001012 FCODE 00001036 NARG 00000000 AGATN 00001018 00001000 REINT START

FIGURE 10.9 Initialization software for 68010/12 processors (Example 10.3).

- 1. What tasks are being accomplished in the software? Specify any special features of 68010/12 software.
- 2. Where is the TRAP #1 routine configured to start after this initialization program has been run?
- 3. For running the program, what mode should the processor be in? Why?
- 4. If the initial value of the corresponding stack pointer is \$0700, diagram the stack frame and its contents.

# Solution

1. Software: Between lines 6 and 11, 256 long words of the original vector table (starting at \$000000) are copied to memory starting at \$2000. Of particular importance is the AGAIN loop. The 68010 and 68012 processors keep this instruction sequence in the internal queue for fast execution.

Between lines 13 and 15, the vector base register is initialized to \$2000. It relocates the vector table at \$00002000. The default vector table remains at \$00000000.

The vector location \$2084 (corresponding to the TRAP #1 vector at the offset of \$84 in the relocated vector table) is loaded with \$3000. The JSR instruction at line 16 takes the program to the FCODE module.

The FCODE module is contained between lines 19 and 24. The SFC is loaded with \$07, which corresponds to FC2 FC1 FC0 = 1.1.1, and refers to the CPU space (see Figure 10.7). The MOVES.W (A3),D2 instruction forces FC2 FC1 FC0 = 1 1 1 and address lines A1-A23 to the 0 . . . 0 condition during the source operand fetch. This emulates a break condition externally. The RTD instruction returns the program to the REINT module, deallocating the stack by eight words. Finally, control is given to the governing operating system by means of the

TRAP #14 call at lines 17 and 18.

- 2. TRAP #1 routine: The vector offset for TRAP #1 is \$84. With the VBR at \$2000, loaded. Thus, the TRAP #1 routine would start at \$00003000.
- 3. Mode of operation: The processor must be in the supervisor mode, since MOVEC
- 4. The stack frame and contents: The processor is in the supervisor mode. The corresponding supervisor stack frame is as follows:

SSP Low address \$06FC \$06FE \$0700 RTD adds \$0702 the specified offset (\$8 in \$0704 this case) to top of \$0706 the stack \$0708

The deallocated space on the stack is usually used by the governing operating system for passing the parameters between local operating systems. The concept of emulation is also demonstrated in the software. While accessing the source operand with the MOVES.W (A3),D2 instruction, a breakpoint condition has been created (or emu-

the reinitialized TRAP #1 vector location is at \$2084, into which \$00003000 is

and MOVES are privileged instructions and can only be used in the supervisor



lated). Detailed discussions on system emulations are beyond the scope of this book; however, references at the end of the chapter may be consulted for further study.

## 10.3 MEMORY FAULT CORRECTION SCHEMES

Memory-access faults (or memory faults) are corrected using virtual memory schemes. There are two methods by which to implement these schemes: the **instruction restart method** and the **instruction continuation method**, both widely used in the computer industry. The 68010 and 68012 processors follow memory-mapped I/O concepts. The memory fault correction schemes are equally applicable for the I/O units of these processors.

### The instruction Restart Method

Each instruction is organized as a sequence of microcoded modules. Figure 10.10 illustrates a microinstruction scheme for a typical instruction:

The instruction op.word is prefetched (during the previous microinstruction mod-

MOVE.W 
$$-(An), -(Am)$$

ule A) and stored in the instruction queue. The microinstruction modules A, B, and C must be sequentially executed for successful execution of the instruction. The memory-access fault can occur during the A, B, or C module.

In the instruction restart method, if a memory fault occurs in any micromodule, it is corrected (if possible) using virtual memory concepts. Then the complete instruction is repeated. For this to happen, the processor should have the internal resources with which to copy all the original values of the registers. Although this puts a tremendous resource burden on the processor, the instruction restart method is considered to be superior to the instruction continuation method. The instruction is finally executed as a complete unit.

## The Instruction Continuation Method

The microinstruction sequence for this method is similar to the sequence of Figure 10.10. The memory fault can occur during the A, B, or C module.

In the instruction continuation method, the memory fault is corrected (if possible) using virtual memory concepts. The instruction execution then continues from the corresponding microinstruction module where the fault was detected and corrected. In this method, it is not necessary to copy the register values, but any interdependence of the destination address and source address (as in the case of MOVE.L —(An),—(An)) may result in inaccurate results. This method is easy to implement, however, and is sufficiently accurate for most applications.



### The 68010/68012 Memory Fault Correction Methods

The 68010 and 68012 microprocessors use the instruction continuation method To the extent poss.ble Motorola Corporation designed the mstruction m.cromodules to be u onally mdependent so as to minimize the fault mteraction. These processor!  $_{\rm u}$  virtual memory schemes to correct memory-access faults. A memory-access fau cannot be corrected if  $_{\rm lt}$  not within the logical memory space of the processors.

# Example 10.4 Memory fault correction schemes.

Suppose the 68010 or 68012 processor must execute the following instruction:

MOVE 
$$L \rightarrow (A1), -(A3)$$

1. Conceptualize the microinstruction sequence.

- 2. Outline the sequence of events if a memory-access fault occurs while accessing the upper word of the source operand.
- **3.** Outline the sequence of events if a memory-access fault occurs while addressing the lower word location of the destination operand.

#### Solution

- **1. Microinstruction sequence:** The sequence is illustrated in Figure 10.11. It consists of five microinstruction modules: A, B, C, D, and E.
- 2. Memory-access **fault in source operand:** Referring to Figure 10.11, the memoryaccess fault occurs during micromodule B. The processor already has completed module A. If possible, the processor corrects the memory-access fault during module B. The microinstruction sequence continues from B to complete the rest of the instruction.
- **3.** Memory-access **fault at destination:** The access fault occurs during micromodule E. The A, B, C, and D modules already have been executed. If possible, the processor corrects the fault during module E, which is the last module. The execution then continues to the next instruction.



In most cases, the op.word for the next instruction is prefetched during the first module of the current instruction. If a fault occurs in prefetching the next op. word, the current instruction is completed first. The memory fault correction for the prefetched op.word begins after the completion of the current instruction.

# 10.4 BUS ERROR EXCEPTION PROCESSING ASSOCIATED WITH VIRTUAL MEMORY

As previously stated, the 68010 and 68012 processors can correct memory-access faults using a virtual memory scheme, if the faults occur within the logical space of the processors. The scheme is implemented as a modified bus error exception. The processor must store more information on the stack for the modified bus error exception to be able to correct memory-related faults. If the memory-access fault occurs beyond the logical memory space, the processor reverts to normal bus error exception processing. These exceptions are handled in the supervisor mode..

# Modified Bus Error (BERR) Exception Processing

In Figure 10.12, the exception vector table for the 68010 and 68012 processors is given. It is similar to that of the 68000, with a few additions; for example, the format error (vector 14 at offset \$038).

Figure 10.13 illustrates the 68010 and 68012 supervisor stack frame for the bus and address error conditions. The processors may stack up to 29 words for memory-related bus error or address error faults. At relative location \$06 from the top of the stack, the format and the vector offset entries are of particular importance. If the 4-bit format is 1000, it refers to a long stack frame with 29 words. If the 4-bit format is 0000, it refers to a short stack of 4 words, as shown. Virtual memory schemes are not implemented if the shorter frame is used. The 12-bit vector offset is the relative offset of the exception in the vector table. This value is \$008 for the bus error, \$024 for the trace, and so on. The stack used is the supervisor stack.

In all types of exceptions, the program counter and the copied status register are automatically stacked. At the conclusion of the exception processing routine, the RTE (return from exception) is executed. The RTE instruction examines the format code (0000 or 1000) and accordingly unstacks either 4 or 29 words into the appropriate registers. Even though the address error stack frame appears to be similar to the bus error stack frame, virtual memory schemes are not implemented for the address error. The address error deals with misaligned access of word or long-word operands at the odd address boundary for the 68000, 68010, and 68012 processors.

Of particular importance is the **special status word** at stack relative location \$08. Detailed in Figure 10.14, the special status word reflects the conditions of the bus activity at the time of the exception. This information is useful in developing appropriate error correction routines using virtual memory principles.

Appropriate software dealing with the normal bus error exception or the modified bus error exception should be written as a part of the governing operating system.

| Vector             | Address |     |                    |                                       |  |
|--------------------|---------|-----|--------------------|---------------------------------------|--|
| Number(s)          | Dec     | Hex | Space <sup>6</sup> | Assignment                            |  |
| 0                  | 0       | 000 | SP                 | Reset: Initial SSP <sup>2</sup>       |  |
| 1                  | 4       | 004 | SP                 | Reset: Initial PC <sup>2</sup>        |  |
| 2                  | 8       | 008 | SD                 | Bus Error                             |  |
| 3                  | 12      | 00C | SD                 | Address Error                         |  |
| 4                  | 16      | 010 | SD                 | Illegal Instruction                   |  |
| 5                  | 20      | 014 | SD                 | Zero Divide                           |  |
| 6                  | 24      | 018 | SD                 | CHK Instruction                       |  |
| 7                  | 28      | 01C | SD                 | TRAPV Instruction                     |  |
| 8                  | 32      | 020 | SD                 | Privilege Violation                   |  |
| 9                  | 36      | 024 | \$D                | Тгасе                                 |  |
| 10                 | 40      | 028 | SD                 | Line 1010 Emulator                    |  |
| 11                 | 44      | 02C | SD                 | Line 1111 Emulator                    |  |
| 12 <sup>1</sup>    | 48      | 030 | SD                 | (Unassigned, Reserved)                |  |
| 13 <sup>1</sup>    | 52      | 034 | SD                 | (Unassigned, Reserved)                |  |
| 14                 | 56      | 038 | SD                 | Format Error <sup>5</sup>             |  |
| 15                 | 60      | 03C | \$D                | Uninitialized Interrupt Vector        |  |
| 16-23 <sup>1</sup> | 64      | 040 | SD                 | (Unassigned, Reserved)                |  |
|                    | 92      | 05C |                    | -                                     |  |
| 24                 | 96      | 060 | SD                 | Spurious Interrupt <sup>3</sup>       |  |
| 25                 | 100     | 064 | SD                 | Level 1 Interrupt Autovector          |  |
| 26                 | 104     | 068 | SD                 | Level 2 Interrupt Autovector          |  |
| 27                 | 108     | 06C | SD                 | Level 3 Interrupt Autovector          |  |
| 28                 | 112     | 070 | SD                 | Level 4 Interrupt Autovector          |  |
| 29                 | 116     | 074 | SD                 | Level 5 Interrupt Autovector          |  |
| 30                 | 120     | 078 | SD                 | Level 6 Interrupt Autovector          |  |
| 31                 | 124     | 07C | SD                 | Level 7 Interrupt Autovector          |  |
| 32-47              | 128     | 080 | SD                 | TRAP Instruction Vectors <sup>4</sup> |  |
|                    | 188     | OBC |                    | -                                     |  |
| 48-63 <sup>1</sup> | 192     | 0C0 | SD                 | (Unassigned, Reserved)                |  |
|                    | 255     | OFF |                    | -                                     |  |
| 64-255             | 256     | 100 | SD                 | User Interrupt Vectors                |  |
|                    | 1020    | 3FC |                    | _                                     |  |



| b15          | b14     | _                   | b12                |         |         |         | 68      |     | b6 | b5 | 64 | Ь3 | b2  | b)    | ьΩ  |
|--------------|---------|---------------------|--------------------|---------|---------|---------|---------|-----|----|----|----|----|-----|-------|-----|
| RR           | *       | IF                  | DF                 | RM      | НВ      | BY      | RW      | *   | *  | *  | *  | *  | FC2 | r — — | FC0 |
| RR ≓<br>IF ≓ | > 11150 | un; () f<br>ructior | or proc<br>1 fetch | essor a | and 1 f | or soft | ware re | run |    | De |    |    |     |       | ·   |

RM  $\Rightarrow$  Read, modify, write cycle

BY  $\Rightarrow$  Byte/word transfer for 1/0

⇒ Reserved

÷ ....

FIGURE 10.14 Special status word for 68010/68012 processors.

We will now present an example problem to review what we have learned about the modified bus error and associated stack frame.

Example 10.5 68010/12 exceptions and supervisor stack frame.

curred. The top of the stack is at \$0600.

NOTES:

1. Vector numbers 12, 13, 16 through 23, and 48 through 63 are reserved for future enhancements by Motorola. No user peripheral devices should be assigned these numbers.

2. Reset vector (0) requires four words, unlike the other vectors which only require two words, and is located in the supervisor program space-3. The spurious interrupt vector is taken when there is a bus error indication during interrupt processing. Refer to Paragraph 4.4.4.

4. TRAP #n uses vector number 32 + n.

5. MC68010/MC68012 only. See Return from Exception Section.

This vector is unassigned, reserved on the MC68000 and MC68008.

6. SP denotes supervisor program space, and SD denotes supervisor data space.

FIGURE 10.12 Exception vector table for the 68010/12 processors. (Courtesy of Motorola, Inc.)

\*Format 0000 for short stack and 1000 for long stack.

DF ⇒ Data fetch HB ⇒ High byte RW ⇒ Read/write for 1/0 FC2, FC1, FC0  $\Rightarrow$  Function codes

Figure 10.15 indicates the contents of the stack after a certain type of exception has oc-

FIGURE 10.15 Supervisor stack frame and contents for the 68010/12-based system (Example 10.5).

| SSP                   | SUPERVISOR STACK                                                                                             | CONTENTS   |
|-----------------------|--------------------------------------------------------------------------------------------------------------|------------|
| \$0600                | 0010 0011 0000 0000                                                                                          | \$2300 SR  |
| \$0602                | 0000 0000 0000 0000                                                                                          | \$0000     |
| \$0604                | 0001 0000 0100 0010                                                                                          | \$1042 PC  |
| \$0606                | 1000 0000 0000 1000                                                                                          | \$8008 [1] |
| \$0608                | 0001 0001 0000 0101                                                                                          | \$1105 [2] |
| \$060A                | 0000 0000 1000 0001                                                                                          | \$0081     |
| \$060C                | 0010 0000 0100 1000                                                                                          | \$2048     |
| \$060E                | 0000 0000 0000 0000                                                                                          | \$0000 [4] |
| \$0610<br>:<br>:<br>: | :<br>Other words of the<br>29-word frame<br>:<br>:                                                           |            |
| \$0638                | Previous stack contents                                                                                      |            |
|                       | <ol> <li>FORMAT/VECTOR</li> <li>SPECIAL STATUS WORD</li> <li>FAULT ADDRESS</li> <li>RESERVED WORD</li> </ol> |            |

- 1. What type of exception has occurred? Can a virtual memory scheme be implemented?
- 2. What are the conditions at the time of this exception, as indicated in the special status word?
- 3. What is the fault address?

# Solution

1. Type of exception: The format/vector offset word at stack location \$0606 is \$8008. This is interpreted as follows:



A bus error exception has occurred, with a long stack frame. Virtual memory implementation is possible.

2. Conditions: Examining the special status word \$1105 at stack location \$0608 and comparing it with the special status word format of Figure 10.14, we observe

| data fetch ←   |
|----------------|
| condition      |
| with processor |
| rerun          |

At the time of the exception (bus error), the processor is attempting to read a word from the supervisor data space.

3. Fault address: The stack contents at \$060A and \$060C contain the fault address.

The governing operating system software uses the stack information in attempting to correct memory-related faults. It should be remembered that the governing operating system is the original or default operating system. It is functional in the supervisor mode. All the local operating systems are functional in the user mode.

# Correction of Memory-related Faults Using Virtual Memory Schemes

The most important application of the virtual memory implementation scheme is to correct memory-access faults. If the memory reference is made to memory that is physically nonexistent, but logically existent, the processor can implement the virtual memory scheme upon receiving the /BERR (bus error) signal. The processor moves the required memory block from the backup memory into the main memory and readjusts the memory pointer reference. It then reruns the bus cycle where the fault occurred and continues with the rest of the instruction and the program.

Virtual memory software is written as part of the modified bus error exception In Figure 10.16 the operating listings of a 68010-based system are given. In this

processing. If the memory reference is beyond the logical address space and a bus error occurs, a normal bus error exception will be executed, as we have already mentioned. software a memory-access fault is simulated and is being corrected. This is written as part of the governing operating system in the supervisor mode. The system has the following memory map:

System ROM/EPROM/RAM  $\Rightarrow$  \$000000 to \$00FFFF (64 kilobytes) System/User RAM  $\Rightarrow$  \$010000 to \$04FFFF (256 kilobytes) RAM buffer  $\Rightarrow$  \$040000 to \$04FFFF (64 kilobytes) System I/O  $\Rightarrow$  \$100000 to \$1003FF (1,024 bytes)

The governing and local operating system programs are contained in the system ROM/ EPROM/RAM. The RAM buffer is used for virtual memory implementation and data transfers.



# Fault address = \$00812048

| LINE ADDI                                                     | R                                                                                        |                                                  |                                                             |
|---------------------------------------------------------------|------------------------------------------------------------------------------------------|--------------------------------------------------|-------------------------------------------------------------|
| 1<br>2<br>3<br>4<br>5                                         |                                                                                          | ;virtual me<br>;fault corr<br>CHIP<br>OPT<br>ORG | mory and memory<br>ection, fiu 3/88<br>68010<br>A<br>\$1400 |
| 6<br>7 000014<br>8 000014                                     | 00 41F8 2000<br>04 4E78 8801<br>08 217C 0000 142                                         | ;VBR reconf<br>LEA<br>MOVEC                      | igured at \$2000<br>\$00002000,A0<br>A0,VBR                 |
| 10<br>11 000014<br>12 000014                                  | 0008<br>10 47F9 0081 204<br>16 3013                                                      | ;fault gene<br>8 LEA \$00<br>MOVE.W              | eration<br>812048,A3<br>(A3),D0                             |
| 16 000014                                                     | LA LEBC ODE4                                                                             | TRAP                                             | system<br>#228,D7<br>#14                                    |
| 18;logica<br>19 000014<br>20 000014                           | ed bus erict fou<br>1 space. Blse no<br>20 4E54 FFFO<br>24 2E2C OOOE<br>28 OC87 OOFF FFF | rmal bus error<br>CORRECT LINK<br>MOVE.L         | \$OE(A4),D7                                                 |
| 22 000014<br>23;trap #<br>24:block                            | 2E 6208<br>2 routine does m<br>transfer between<br>and adjust memo                       | BHI.S<br>emory management<br>backup and main     | NORMAL                                                      |
| 25;memory<br>26 000014<br>27 000014<br>28 000014<br>29 000014 | 30 4842<br>32 4871<br>34 485C                                                            | TRAP<br>NOP<br>UNLK<br>RTE                       | #2<br>R4                                                    |
| 30;to nor                                                     | mal bus error<br>38 2878 0008<br>3C 4ESC<br>3E 4EDS                                      |                                                  | C \$0008,AS<br>A4<br>(AS)                                   |
| ASSEMBLER                                                     | ERRORS = 0                                                                               |                                                  |                                                             |
|                                                               |                                                                                          | SYMBOL TABLE                                     |                                                             |
| CORRECT                                                       | 00001420 NARG                                                                            | DDDDDDDD NORM                                    | AL 00001438                                                 |

**FIGURE 10.16** Bus error/memory-access fault correction software for the 68010 (Example 10.6).

At lines 7 and 8, the VBR is initialized to \$2000. This is the base address for the new vector table. At line 9, the modified bus error exception routine address (CORRECT) is loaded into new bus error vectored location \$2008.

This system does not have physical memory beyond \$04FFFF (refer to Section 10.1). Hence, the instructions

LEA \$00812048,A3 and MOVE (A3),D0

at lines 11 and 12 simulate a bus error condition. Location \$812048 is beyond the physical memory, but is contained in the logical memory. While executing the instruction

# MOVE.W (A3),D0

the processor receives a  $\overline{\text{BERR}}$  signal when the source operand is addressed. The processor then stacks the internal register and control information on the stack (see Figure 10.15).

The processor goes to the modified bus error routine (CORRECT) between lines 19 and 29. The fault address is stored at an offset \$0A with reference to the current SSP (supervisor stack pointer). The A4 register is configured as the frame pointer by the LINK instruction. At lines 20 and 21, the logical address limit is checked against the fault address. If the fault address is beyond the logical address, the program goes to the normal bus error exception routine (NORMAL) at line 31.

The modified bus error routine is executed via the TRAP #2 routine. This is the memory fault correct software. It transfers 64 kilobytes from the RAM buffer into the backup memory to create space for the new virtual memory data to be brought in. It then transfers a 64-kilobyte block ( $\pm 32$ K) around the fault address from the backup memory into the RAM buffer. In this instance, this block would be \$80A048 to \$81A047. It adjusts the memory reference as shown:



A detailed listing of the TRAP #2 routine is very complex; hence, we have chosen not to include it given the constraints of the text.

At line 28, the stack is unlinked. The following RTE instruction returns the processor to the condition that existed at the time of the bus error. The processor then reruns the bus cycle that generated the bus error. It obtains the source operand from a virtual location \$00812048 (which is now a physical location \$00042048 in the RAM buffer) and successfully completes the faulted instruction

# MOVE.W (A3),D0

If the bus error is a normal bus error, the NORMAL module between lines 31 and 33 will be executed. After unlinking the stack, the program jumps to the address contained at vector location \$08. This corresponds to the bus error vector in the default vector table, and the governing operating system executes the normal bus error exception routine.

At the end of the memory-access fault correction, control is returned to the governing operating system by means of the TRAP #14 function at lines 15 and 16. We will now present an example problem to gain further insight into the memory fault correction schemes.

## Example 10.6 Memory fault correction concepts and software.

Refer to the software of Figure 10.16.

- 1. Describe how the virtual memory concepts are implemented and how the memoryaccess fault is corrected.
- 2. What is the difference between the default vector table and the modified (or relocated) vector table?
- 3. Why are the LINK and UNLK required?

# Solution

1. Memory fault correction: The memory-access fault address has been stacked at an offset \$0A. A 64-kilobyte block around that address has been moved from the backup memory into the RAM buffer and the memory reference has been readjusted. The addressed operand in the virtual address (\$812048) will be found at the real physical address (\$042048).

# Fault Address = \$812048 Corrected Address = \$042048

**2. Default and modified vector tables:** The default table is the table at power-up reset (VBR = 0). It refers to the original (or governing) operating system exception vec tors.

The modified vector table is set up separately and is accessed with a finite value in VBR to facilitate local operating system or user-defined exception processing. In our example, VBR = \$2000. All the default vectors are copied to the new vector table (refer to Section 10.1). But the bus error vector address is changed, and the bus error exception routine is different in the modified table. Initially, the processor goes to the default table; after adjusting VBR, it goes to the modified table.

3. **LINK and UNLK:** These instructions are required to access to the stack without de stroying the stack pointer.

There are memory correction schemes that are more involved than those presented here. However, virtual memory implementation schemes remain the same. Because of the difference in the stack frames of the 68000 and 68010 processors, there may be some inconsistencies if a 68000-based system is upgraded to a 68010. Some of the governing operating system exception routines may have to be rewritten to maintain full functional compatibility.

# 10.5 SUMMARY

In this chapter we introduced the concepts of virtual memory and the virtual machine. We also examined the specific features of the 68010 and 68012 microprocessors with which these schemes are implemented.

The full addressing capability of any processor refers to the logical address space. In many instances, all the available logical address space is not filled with the memory or I/O. Only a part of the available address space, called the physical space, is filled with real and existing devices. With the help of virtual memory schemes, it is possible to realize the entire logical memory space with only a limited amount of physical memory present in the system.

Virtual memory refers to a memory reference contained in the logical space of the processor, but not contained in the physical memory around the processor. If the virtual memory reference is contained in a backup memory, such as a disk, the backup memory block can be moved into the physical memory buffer under the control of the operating system software. Moreover, the memory reference pointers are adjusted to refer to the contents in the buffer area.

At times, the hardware I/O resources may not be physically available, but software to operate them needs to be developed. Hardware resources can be emulated using virtual memory implementation principles. This embodies the concept of the virtual machine; that is, that nonexistent I/O resources can be emulated under software control. The emulated virtual machine resources are under the control of the governing operating system.

The 68010 and 68012 processors have extra registers with which to handle virtual memory and virtual machine schemes. They are the VBR (vector base register) and the SFC and DFC (source function code and destination function code registers). The stack format for the 68010 and 68012 processors is different from that of the 68000. The 68010/12 format allows for 29 words for the bus and address error exceptions.

The 68010 processor is pin compatible with the 68000 and can address 16 megabytes of logical memory. The 68012 processor has seven more address lines, and can access 2 gigabytes of logical memory. Both the 68010 and 68012 are fully software compatible with the 68000.

Memory-access faults can be corrected using virtual memory schemes, if the memory access is in the logical memory space. A bus error signal will be generated when a reference to the nonexistent physical memory is made. In response to this signal, the 68010 and 68012 processors go into bus error exception processing. Using virtual memory concepts, a block of memory is moved from the backup memory into the physical memory. The memory reference is adjusted and the memory-access fault is corrected.

There are two methods for memory-access fault correction: the restart method, and the continuation method. In the restart method, the complete instruction where the fault occurred is repeated after the fault correction. In the continuation method, the instruction is continued from the microstep within the instruction after the memory-access fault correction. The restart method requires that all the microcoded operations of an instruction and associated operands be stored. This requires tremendous register resources, as well as other resources. The restart method, however, executes the instruction as a unit.

The continuation method is considered sufficiently accurate for most applications and does not require that all the microcoded operations of an instruction be stored. The continuation method executes the instruction in parts rather than as a single unit, however. The 68010 and 68012 processors use the continuation method.

### PROBLEMS

- 10.1 Redefine the virtual memory and virtual machine concepts in your own terms.
  - (a) Give an example of virtual memory.
  - (b) Give an example of the virtual machine.
- 10.2 Explain why the virtual memory scheme cannot be implemented in the 68000 microprocessor.
  - If external resources are added, can the 68000 be changed to a 68010 processor? Explain.
- 10.3 Can virtual memory schemes be implemented for
  - (a) an address error?
  - (b) a zero-divide error?

State your reasons in each case

- 10.4 Can virtual machine concepts be extended to replace real machines?
  - (a) If so, can the real machines be dispensed with?
  - (b) If not, what is the real usefulness of the virtual machine concept?
- **10.5** Refer to the system we considered in Examples 10.1 and 10.2. The following instruction is executed:
  - ADDX.L -(A1), -(A2)
  - AI =\$080004 and A2 =\$08345C.
  - (a) Which memory block gets moved from the backup memory into the buffer area? Why?
  - (b) Where are the A1 and A2 register values stored? Why?(c) What are the adjusted values of the A1 and A2 registers?
- **10.6** A printer I/O system is emulated using virtual machine concepts. The printer has a print buffer of 2,048 bytes and six different control signals, such as ready to send, clear to send, paper out, and the like. In addition, the printer has a 256-byte character buffer.
  - (a) To emulate the printer as a virtual machine, how much memory is required?(b) If the printer were to send an interrupt, how would this be accomplished?
- **10.7** The 68000 and 68010 are pin compatible with one another.
  - (a) Will software written for the 68000 run completely using the 68010? Are there any

instances in which a marked difference between the two processors will be evidenced?

(b) Repeat (a) if the software is intended for the 68010 and the device is then replaced by 68000,

10.8 In a multiuser environment, reconfigure

(a) the vector table for user 1 starting at \$2000;

(b) the vector table for user 2 starting at \$4000.

Initialize locations so that the TRAP #2 routine for user 1 starts at \$1600 and for user 2 at \$1800.

- 10.9 If the RTD instruction is not available (as is the case with the 68000),
  - (a) write a sequence of instructions to accomplish the task illustrated in Figure 10.9;
    (b) compute the time of execution for (a) and compare this with the RTD instruction execution time.
- 10.10 If possible, rewrite the software of Figure 10.9
  - (a) to emulate an interrupt acknowledge cycle;
  - (b) to emulate the user I/O cycle,
- 10.11 Obtaining the timing information from the data sheets of the 68010,
  - (a) formulate the T(R/W) values for the software of Figure 10.9.(b) compute the time of execution for (a).
- 10.12 In the 68010 and 68012 processors, explain how different vector tables are used for different users. For example,
  - User 1 Vector table starting at \$2000
  - User 2 Vector table starting at \$4000

Where is the default vector table for both users? 10.13 Indicate the micromodules for the following instructions:

- (a) MOVE.L (A1)+,-(A3)(b) MOVE.L -(A1), (A3)+
- 10.14 Repeat problem 10.13 for the following:

(a) ADDI.B #\$43,\$14(A1,D1.W)
(b) EOR.W D2,(A1)+

10.15 Suppose a memory-access fault occurs while accessing the source operand in the instructions that follow. Outline the sequence of events with appropriate micromodules.
(a) ADDX.L -(A1),-(A1)
(b) ADD.L (A1)+.D2

Compare the micromodules and specify which takes more modules and time. Explain your answer.

- 10.16 Can the faults occurring in the following sequence of instructions be corrected by the 68010? State all of your reasons.
  - (a) MOVEA.L #\$12345678,A1 ROL.W (A1)
     (b) JMP \$12345

10.17 Why is the restart method considered superior to the continuation method in the field of virtual memory? Give at least three reasons.

What additional resources are required to implement the restart method?

- 10.18 Are the stack structures for the 68000 and 68010 completely compatible with one another? Why or why not?
  - (a) If there is any incompatibility, does it create any hardware or software problems in interchanging the 68000 and 68010?
  - (b) Can the incompatibility, if it exists, be corrected by external hardware? Give your reasons.

10.19 Given the following software:

#### PC Instruction



an error condition has resulted in accessing the data space at \$1003.

- (a) What type of error must it have been?
- (b) Indicate the contents of the stack when the 68010 recognizes the error and is ready to respond with appropriate exception processing.
- 10.20 Repeat Problem 10.19 for the following:

| <b>PC</b> | Instruction                    |
|-----------|--------------------------------|
| \$1000    | ADDQ.W #\$03,\$12345678<br>NOP |
|           | :                              |
| \$100E    | CLR.B AG                       |

10.21 Specify two exception conditions in which the format code will be

### (a) \$0000; (b) \$1000.

- 10.22 Rewrite the software of Figure 10.16 so that the physical memory buffer is located between
  - (a) \$15000 and \$18000;
  - (b) \$40000 and \$44000.
- 10.23 Rewrite the software of Figure 10.16 to make it more efficient
  - (a) in terms of execution time;
  - (b) in terms of the program memory space.
- 10.24 In Example 10.6, suppose the fault-causing instruction is changed to

ADD.L D7,(A5)+

A5 = \$887766AA.

(a) Specify the sequence of events.

(b) Can the error be corrected by virtual memory schemes? If so, show how it can be done. If not, specify your reasons and validate them with practical examples.

# **ENDNOTES**

- 1. Motorola, Inc. 68010 Data Book. Phoenix, AZ: Motorola Technical Operations, 1983.
- 3. MacGregor, D., and Mothersole, D. "Virtual Memory and the 68010." IEEE Micro
- 4. Motorola, Inc. MTT8 68000 Course Notes. Phoenix, AZ: Motorola Technical Operations,
- 5. Motorola, Inc. M68000 16/32-Bit Microprocessor Programmer's Reference Manual, Fifth Edition. Englewood Cliffs, NJ: Prentice-Hall, 1987.
- 6. MacGregor, D., and Moyer, B. "Built-in Tight Loop Mode Raises Microprocessor Performance (68010)." Electronic Design 31, no. 22 (1983).
- 7. Miller, M.A. "The 68000 Family of Microprocessors." Chap. 10 in The 68000 Microprocessor: Architecture, Programming, and Applications. Columbus, OH: Merrill,

-----.....

2. Motorola, Inc. 68010/68012 Data Book. Phoenix, AZ: Motorola Technical Operations, 1985.

# **CHAPTER**

# 68020 and 68030 Architecture, **Organization, and Applications**

# 11.0 INTRODUCTION

#### Objectives

In this chapter we will study:

The general architecture of the 68020 and 68030 processors The additional resources of the 68020 and 68030 Cache memory organization concepts Functional improvements of the 68020 and 68030

The 68020 is a 32-bit microprocessor with individual 32-bit address and data buses. It has a 4-gigabyte logical address space. In addition to all the internal resources of the 68010 and 68012 processors, it has a chip instruction cache memory. These additional features increase the overall throughput of a 68020-based system as compared to the earlier members of the 68000 family.

The 68030 is an extension of the 68020 processor. Additional features of the 68030 include the data cache memory and a paged memory management unit (PMMU, or simply MMU) on the chip itself, further enhancing the throughput of 68030-based systems.

Study of the material in this chapter will provide a comprehensive introduction to the 68020 and 68030 processors, cache memory, and memory management operations.

# 11.1 GENERAL ARCHITECTURE OF THE 68020

FIGURE 11.1 General architecture of the 68020. (Courtesy of Motorola, Inc.)





The 68020 is contained in a 114-pin grid-array package and is fabricated with VLSI MOS technology. Figure 11.1 illustrates the internal architecture of the 68020. It contains all the resources of the 68000, 68010, and 68012, along with some additional resources and modified resources to facilitate cache memory implementation.

# Additional Resources and Modified Resources of the 68020

There are three stack pointers in the 68020: the user stack pointer USP (A7) in the user mode, the interrupt stack pointer ISP (A7') in the supervisor mode, and the master stack pointer MSP (A7") in the supervisor mode. The USP handles the user stack operations. The ISP handles the interrupt exceptions and the MSP handles the rest of the exceptions. Selection of the stack pointer to be used is made with the help of the S and M bits in the system byte of the status register.

The cache control and the cache address registers (CACR and CAAR) are used to control the cache memory operations. The vector base register (VBR) and the alternate



source and destination function code registers (SFC and DFC) are used in much the same way as in the  $68010 \text{ processor.}^2$ 

The user byte of the status register is similar to that of the 68000 processor. The system byte is modified, however, as shown in Figure 11.2. The Tl and TO bits determine the trace mode of operation. The S and M bits select the stack pointer. The interrupt mask bits 12, II, and 10 are similar to those of 68000.

#### CDIS Function codes FC0-FC2 Cache control Interrupt priority [PL0-[PL2] Address bus A0-A31 Interrupt control IPEND MC68020 Data bus D0-D31 AVEC Microprocessor ΒR SIZ0 Bus Transfer size SIZI ΒĜ administration BGACK control ECS **OCS** RESET Bus HALT RMC exception ĀŠ BEAR control Asynchronous DS bus R/Ŵ ÇLK control DBEN DSACK0 $V_{cc}(8)$ GND (8) DSACK1

FIGURE 11.3 Functional pin structure of the 68020. (Courtesy of Motorola, Inc.)

## Address, Data, and Control Buses

Figure 11.3 indicates the functional pin structure of the 68020 and Figure 11.4 describes the signals. The address and data buses are extended to 32 bits each. Eight-bit byte, 16-bit word, or 32-bit long-word data operands can be transferred in a single bus cycle. The function code outputs FC2, FC1, and FCO specify the type of address space and the processor condition. The SIZ1 and SIZO outputs indicate the number of bytes to be further transferred at the beginning of each bus cycle.

The external cycle start (/ECS) output indicates that a bus cycle is beginning. The operand cycle start (/OCS) output is asserted during the first bus cycle of an operand transfer. The read-modify/write cycle (/RMC) output is similar to that of the 68012 pro cessor; it indicates that the current bus cycle is an indivisible read-modify/write bus cy cle.

The address strobe (AS) and the data strobe (DS) outputs indicate the validity of the address and the data on the respective buses. The read/write (R/\*W) output indicates the read or write bus cycle. The data buffer enable (/DBEN) output is similar to the /DS signal, but is used to enable the external data buffers. The /DTACK input of the 68000 is

| Signal Name                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Mnemonic         |                                                                                                                                                                                                             |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Address Bus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | A0-A31           |                                                                                                                                                                                                             |
| Data Bus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | D0-D31           | 32-bit address bus used to address any of 4,294,967,296 bytes.                                                                                                                                              |
| Function Codes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | FC0-FC2          | 32-bit data bus used to transfer 8, 16, 24, or 32 bits of data per bus cycle.                                                                                                                               |
| Size                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | SIZO             | under the second second to identify the address space of each bur such                                                                                                                                      |
| Read-Modify-Write Cycle                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | SIZ1<br>RMC      | signals, together with A0 and A1, define the active sections of the data bus.<br>Provides an indicator that the current bus cycle is not of an indicator that the current bus cycle is not of an indicator. |
| External Cycle Start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ĒCS              |                                                                                                                                                                                                             |
| Operand Cycle Start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | OCS              | Provides an indication that a bus cycle is beginning.                                                                                                                                                       |
| Address Strobe                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                  | Identical operation to that of ECS except that OCS is asserted only during the first bus cycle of an operand transfer.                                                                                      |
| Data Strobe                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | AS               | Indicates that a valid address is on the bus.                                                                                                                                                               |
| Read/Write                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | DS               | Indicates that valid data is to be placed on the data bus by an external device or has been placed on the data bus by the MC68020.                                                                          |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | R/W              | Defines the bus transfer as an MPU read or write.                                                                                                                                                           |
| Data Buffer Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | D8EN             | Provides an enable signal for external data butters.                                                                                                                                                        |
| Data Transfer and Size Acknowledge                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | DSACKO<br>DSACK1 | Bus response signals that indicate the requested data transfer operation is com-<br>pleted. In addition, these two lines indicate the size of the external bus port on a<br>cycle-by-cycle basis.           |
| ache Disable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | CDIS             |                                                                                                                                                                                                             |
| terrupt Priority Level                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | IPLO-IPL2        | Dynamically disables the on-chip cache to assist emulator support.                                                                                                                                          |
| Ulovector                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | AVEC             | Provides an encoded interrupt level to the processor.                                                                                                                                                       |
| Rerrupt Pending                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | IPEND            | Requests an autovector during an interrupt acknowledge cycle                                                                                                                                                |
| us Request                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | BR               | indicates that an interrupt is pending.                                                                                                                                                                     |
| us Grani                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | RG               | Indicates that an external device requires bus mastership.                                                                                                                                                  |
| is Grant Acknowledge                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                  | Indicates that an external device may assume bus mastership                                                                                                                                                 |
| set                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | BGACK            | indicates that an external device has assumed bus mastership                                                                                                                                                |
| əfq                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | RESET            | System reset.                                                                                                                                                                                               |
| IS Error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | HALT             | Indicates that the processor should suspend bus activity.                                                                                                                                                   |
| under state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state state stat | BERR             | Indicates an invalid or illegal bus operation is being attempted.                                                                                                                                           |
| wer Supply                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | CLK              | Clock input to the processor.                                                                                                                                                                               |
| ound                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Vcc              | +5 ±5% volt power supply.                                                                                                                                                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | GND              | Ground connection.                                                                                                                                                                                          |

FIGURE 11.4 The 68020 signal description. (Courtesy of Motorola, Inc.)

split into /DSACKO and /DSACK1. These two inputs are encoded to specify byte, word, or long-word transfers on the data bus.<sup>3</sup>

The cache disable (/CDIS) input disables the internal cache memory. The interrupt priority inputs (/IPL2, /IPL1, and/IPLO) are similar to those of the 68000 processor. The autovector (/AVEC) input signifies an autovectored interrupt condition. The interrupt pending (/IPEND) input signifies a pending interrupt. The bus arbitration signals (the bus request (/BR) input, the bus grant (/BG) output, and the bus grant acknowledge (BGACK) input) are similar to those of the 68000 processor and are used for the DMA type of transfers. The system control signals (/RESET, /HALT, and /BERR) are also similar to those of the 68000 processor. The device operates on 5 volts  $V_{DD}$ .

# Data Formats, Memory, and I/O Interface Schemes

The 68020 is designed to facilitate byte, word, or long-word data transfers on even or odd address boundaries. However, the op.word (instruction word) fetches must be on even word boundaries to maintain code compatibility with the earlier 68000 family members. If op.word fetches are not on even word boundaries, an address error will occur.



FIGURE 11.5 Memory and I/O general interface scheme for the 68020.

Figure 11.5 illustrates a typical memory interface scheme and associated data formats. The 68020 uses memory-mapped I/O concepts similar to those of the other members of the family; thus, the memory and I/O interface schemes are similar. An 8-bit byte port (b7-b0) is connected to data lines D31-D24. A 16-bit word port (b15-b0) is connected to data lines D31-D16. A 32-bit long-word port (b31-b0) is connected to data lines D31-D0. The Al and A0 address lines and the SIZ1 and SIZ0 size outputs are decoded to provide the byte enable signals BE0, BE1, BE2, and BE3. These signals enable the transfer of appropriate bytes.

Figure 11.6 indicates the DSACK and SIZ signal responses for different data sizes. Depending upon the address and the alignment, there can be one, two, three, or four byte transfers in a single bus cycle. We will now present an example problem to review basic concepts relating to the 68020 processor.

| DSACKI | DSACK0 | Data Bus<br>Activity | <u>SIZI</u> | <u>sizo</u> | Data Size    |
|--------|--------|----------------------|-------------|-------------|--------------|
| 1      | 1      | not selected         | 1           | 1           | 3 bytes more |
| 1      | 0      | byte selected        | 1           | 0           | 2 bytes more |
| 0      | 1      | word selected        | 0           | 1           | 1 byte more  |
| 0      | 0      | iong word selected   | 0           | 0           | 4 bytes more |

(a)

FIGURE 11.6 Data bus activity and selection as functions of (a) DSACK and (b) SIZ

Example 11.1 68020 architecture and data formats. A 68020-based system has the following memory and I/O map:

Main memory (32-bit wide) ⇒ \$00000000 to \$00FFFFFF

- 1. What are the conditions of the system byte at power-up reset? What is the default value of VBR on reset?
- 2. The processor is executing the following instruction:

MOVE.L D0,(A1)

with D0 =\$012A46AB; A1 = \$00004000. Indicate the data transfers on the bus, along with the DSACKx and SIZx signals.

**(b)** 

System I/O (16-bit wide)  $\Rightarrow$  \$01000000 to \$0100FFFF (8-bit wide)  $\Rightarrow$  \$01010000 to \$010103FF

3. The processor is executing the following instruction:

### MOVE.L D0,(A2)

with D0 = \$012A46AB; A2 = \$01000401. Indicate the data transfers on the bus, along with the DSACKx and SIZx signals.

### Solution

1. System byte and VBR on reset: In order to be compatible with the other members of the 68000 family, the system byte is set up for trace off, stack pointer ISP, and interrupt mask level 7. Similarly, the VBR is set up for the all-zero condition. The system byte and the VBR are as shown:



2. MOVE.L D0,(A1): The destination effective address (A1) = \$00004000 is evenly divisible by 4; as such, it is long-word aligned. All 32 bits of data from D0 are transferred to the destination in a single bus cycle, as shown:



3. MOVE.L D0,(A2): The 16-bit port is connected between data lines D31 and D16. The destination effective address (A2) = \$01000401 is at an odd byte boundary and is misaligned. However, the long-word data operand is transferred in three bus cycles. During the first bus cycle, the most significant byte (MSB) operand OP0 is transferred to location \$01000401. During the second bus cycle, byte operands OP1 and OP2 are transferred as a word to location \$01000402. During the third bus cycle, the LSB operand OP3 is transferred to location \$01000404. The sequence of operations is as shown:



The DSACK and SIZ signals specify the actual bus activity. During the first bus cycle, 4 bytes were meant to be transferred, but only one could be transferred. During the second bus cycle, 3 bytes were still meant to be transferred, but only two could be transferred (as a word). During the third bus cycle, the last and remaining

With the help of the DSACK and SIZ signals, it is possible to execute aligned or misaligned data transfers with equal ease. Misaligned transfers take more bus cycles, however.

To further familiarize the reader with the configuration of the 68020 processor, the internal block diagram and layout structure are presented in Figures 11.7 and 11.8.

# 11.2 ADDITIONAL ADDRESSING MODES AND INSTRUCTIONS FOR THE 68020

The table of Figure 11.9 (p. 316) indicates the addressing modes of the 68020. In addition to all the addressing modes of the 68000, it has memory indirect and program counter indirect addressing modes. The associated base and outer displacements (bd and od) can be up to 32 signed bits.<sup>5</sup>

# Memory Indirection Addressing Modes and Scaling

Whenever an index register (Dn or An) is used, its contents are multiplied by a scale factor. In computing the effective address, the scale factor can be 1, 2, 4, or 8. The scaling enables addressing at relative displacements of the byte, word, long word, or quad word (8 bytes). The term memory indirect addressing is used in reference to a memory location, the contents of which form the base address of the operand. The effective address of the operand is obtained by properly adding the scaled index register

| LSB<br>OP3 |        |             |           |           |
|------------|--------|-------------|-----------|-----------|
| AB         |        |             |           |           |
| \$01000401 | DSACK1 | DSACKO<br>0 | SIZI<br>0 | SIZO<br>0 |
| \$01000403 | 0      | I           | I         | 1         |
| \$01000405 | t      | 0           | 0         | 1         |





contents and the base unci outer displacements to the indirect address. This addressing scheme uses a memory location as a memory pointer.

Figure 11.10 (p. 317) indicates the results that follow from using the new addressing modes. When scaling is used, the physical value of the index register is not changed. In memory indirect postindexing, the contents of the memory indirect address are obtained first. The index and the outer displacements are further added to obtain the effective address of the operand. In memory indirect preindexing, the memory indirect address is obtained after indexing. The outer displacement is further added to obtain the HA of the operand.

In the program counter indirect and program counter memory indirect addressing modes, the program counter is used instead of an address register. These modes are suitable for relocatable code generation.

# **Bit-Field Type of Instructions**

The bit-field instructions for the 68020 arc given in Figure 11.11 (p. 318). These instructions address and manipulate a bit field of variable width (1 to 32 bits), starting from a given offset of the effective address. The syntax of the single operand instruction is



FIGURE 11.8 The 68020 internal structure and layout. (Courtesy of Motorola, Inc.)

# BFxxx (ea) {offset: width}

If the instruction is of the double-operand type, the other operand is a data register Dn. 'I he offset and width fields can be specified as immediate operands or as Dn operands. 1'or all bit-field instructions, the bit field is first tested and the N and Z flags are adjusted accordingly. The specified bit-field operation is then carried out. In Figure 11.12 (p.  $\blacksquare M^{1}$ -)) some typical bit-field instruction operations are given in order of complexity.

The bit-field instructions are very helpful in handling bit fields of variable lengths and at any effective address location. In the absence of these instructions, a series of ■"Mructions must be written to accomplish the tasks of this type.

| Addressing Modes                                                                               | Syntax                                    |
|------------------------------------------------------------------------------------------------|-------------------------------------------|
| Register Direct                                                                                |                                           |
| Data Register Direct                                                                           | Dn                                        |
| Address Register Direct                                                                        | An                                        |
| Register Indirect                                                                              |                                           |
| Address Register Indirect                                                                      | (An)                                      |
| Address Register Indirect with Postincrement                                                   | (An) +                                    |
| Address Register Indirect with Predecrement                                                    | - (An)                                    |
| Address Register Indirect with Displacement                                                    | (d <sub>16</sub> ,An)                     |
| Register Indirect with Index                                                                   |                                           |
| Address Register Indirect with Index (8-Bit Displacement)                                      | [dg,An,Xn}                                |
| Address Register Indirect with Index (Base Displacement)                                       | (bd,An,Xn)                                |
| Memory Indirect                                                                                |                                           |
| Memory Indirect Post-Indexed                                                                   | ([bd,An],Xn,od)                           |
| Memory Indirect Pre-Indexed                                                                    | ([bd,An,Xn],od)                           |
| Program Counter Indirect with Displacement                                                     | {d <sub>16</sub> ,PC)                     |
| Program Counter Indirect with Index                                                            |                                           |
| PC Indirect with Index (8-Bit Displacement)                                                    | (dg,PC,Xn)                                |
| PC Indirect with Index (Base Displacement)                                                     | (bd,PC,Xn)                                |
| Program Counter Memory Indirect                                                                |                                           |
| PC Memory Indirect Post-Indexed                                                                | {[bd,PC],Xn,od}                           |
| PC Memory Indirect Pre-Indexed                                                                 | ([bd,PC,Xn],od)                           |
| Absolute                                                                                       |                                           |
| Absolute Short                                                                                 | xxx.W                                     |
| Absolute Long                                                                                  | xxx.L                                     |
| Immediate                                                                                      | # <data></data>                           |
| IOTES:                                                                                         |                                           |
| Dn = Data Register, D0-D7                                                                      |                                           |
| An = Address Register, A0-A7                                                                   |                                           |
| d <sub>8</sub> , $d_{16}$ = A twos-complement, or sign-extended displacement; added as part of | f the effective address calculation; size |
|                                                                                                |                                           |

bits (d16 and d8 are 16- and 8-bit displacements); when omitted, assemblers use a value of zero.

Xn = Address or data register used as an index register; form is Xn.SIZE\*SCALE, where SIZE is .W or .L (indicates index register size) and SCALE is 1, 2, 4, or 8 (index register is multiplied by SCALE); use of SIZE and/or SCALE is optional bd = A twos-complement base displacement; when present, size can be 16 or 32 bits. od = Outer displacement, added as part of effective address calculation after any memory indirection; use is optional with a size

of 16 or 32 bits. PC = Program Counter

< data > = Immediate value of 8, 16, or 32 bits

() = Effective address

{ I = Use as indirect address to long word address.

FIGURE 11.9 Addressing modes of the 68020. (Courtesy of Motorola, Inc.)

Packed and Unpacked BCD Instructions

The PACK instruction is used to reduce a word-sized two-digit BCD operand into a packed 8-bit two-digit BCD operand. The UNPK instruction increases a byte-sized two-digit BCD operand into an unpacked 16-bit two-digit BCD operand. Examples follow.

**PACK D2,D3,#\$0000:** The specified immediate data (0000) word is added to the source operand in the D2 register. The upper 4 bits of each byte are discarded and the lower 4 bits of each byte are packed into the destination register D3.

#### INITIAL A0 = \$0000 ABCD;D0 = D1 =

A1 = \$0000008;A2 = \$00003000;D2 =

A3 =\$00004000; D3 =

# 1. ARI with base displacement, in

MOVE.L (08, A3, D1.W \* 4),D4 : : : : bd ARI index scale

 $(ARI \Rightarrow Address register indirect)$ Long-word contents correspo EA are moved into D4 regist

### 2. Memory indirect postindexed:

MOVE.L ([\$1800,A2], D1,W \* 8, : : : : bd ARI index scale m contents of above me

> Long-word contents correspon EA are moved into D4 registe

#### 3. Memory indirect preindexed:

MOVE.L ([\$0800,A2, D1.W \* 8]. : : : : bd ARI index scale

> nıe contents of above me

Long-word contents correspon EA are moved into D4 registe

FIGURE 11.10 The 68020 scaling and memory indirect addressing modes.

| CONDITIONS                                               |                                                                                                                                             |
|----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| \$00000004;<br>\$00000200;<br>\$0000F0F0;<br>\$012A46AB; | \$00004800 0000<br>4802 2222<br>4804 4444<br>4806 6666<br>4808 8888<br>480A 0000                                                            |
| ndex, and scalir                                         | g:                                                                                                                                          |
| 4<br>onding to<br>ter ⇒                                  | EA calculation:<br>A3.L $00004000 +$<br>D1.W*4 $00000800 +$<br>bd $00000008$<br>EA = $00004808$<br>D4 = $88880000$                          |
| :<br>le od                                               | EA calculation:<br>A2.L \$00003000 +<br>bd \$00001800<br>ddress = \$00004800<br>ddress \$00002222 +<br>D1.W*8 \$00001000 +<br>od \$000015E0 |
| ending to<br>ter ⇒                                       | $EA = \frac{300001320}{800004802}$ $D4 = \$22224444$                                                                                        |
| . \$25E4),D4<br>:<br>e od                                | EA calculation:<br>A2.L \$00003000 +<br>D1.W*8 \$00001000 +                                                                                 |
| emory indirect a<br>emory indirect a                     | bd \$00000800<br>idress = \$00004800                                                                                                        |
| nding to<br>er ⇒                                         | D4 = \$66668888                                                                                                                             |
|                                                          |                                                                                                                                             |

| Instruction | Operation                                                         |
|-------------|-------------------------------------------------------------------|
| BFCHG       | Test bit field and change from 1 to 0, or vice versa.             |
| BFCLR       | Test bit field and clear.                                         |
| BFEXTS      | Extract signed bit field from source and place into destination.  |
| BFEXTU      | Extract unsigned bit field from source and place into destination |
| BFFFO       | Find first one in the bit field.                                  |
| BFINS       | Insert bit field at specified address.                            |
| BFSET       | Test bit field and set condition codes.                           |
| BFTST       | Test bit field and set or reset N and Z flags.                    |

Flag conditions: N set if the MSB of the bit field is 1.

Z set if the bit field is all-zero. V cleared; C cleared; X unaffected.

FIGURE 11.11 Bit-field instructions for the 68020.

|   | Initially D2 =    | \$     | х    | x   | х   | Х | 3 | 7 | 3 | 5        |  |
|---|-------------------|--------|------|-----|-----|---|---|---|---|----------|--|
| + | data element =    | \$     |      |     |     |   | 0 | 0 | 0 | <b>0</b> |  |
|   |                   |        |      |     |     |   |   | : |   | :        |  |
|   | discard upper 4 h | oits ( | of e | ach | byt | e |   | : |   | :        |  |
|   | and pack lower 4  |        |      |     |     |   |   | 7 |   | 5        |  |
|   |                   |        |      |     |     |   |   | Ń |   | :        |  |
|   | Final D3 value =  | = \$   | x    | х   | х   | х | х | х | 7 | 5        |  |

The source and destination operands can also be specified by the predecrement ARI addressing mode (PACK -(An),-(Am),#data).

UNPK D3,D4,#\$3030: The source operand in the D3 register is unpacked from 8 bits to 16 bits, with the upper 4 bits of each byte set to zero. The specified data (\$3030) is added to the unpacked operand. The resulting 16-bit operand is placed in the destination register D4.

|   | Initially D3 =   | \$ | X | X | х | Х | X. | Х | 7 | 5 |  |
|---|------------------|----|---|---|---|---|----|---|---|---|--|
|   |                  |    |   |   |   |   |    | 1 | 1 | : |  |
|   | unpacked operand | ł  |   |   |   |   | 0  | 7 | 0 | 5 |  |
| + | data element =   | \$ |   |   |   |   | 3  | 0 | 3 | 0 |  |
|   | Final D4 value = | \$ | х | х | х | х | 3  | 7 | 3 | 5 |  |

The source and destination operands can also be specified by the predecrement ARI addressing mode (UNPK -(An),-(Am),#data).

In the preceding example, with a data element of \$3030, the UNPK instruction has converted a normal BCD value into a corresponding ASCII value (BCD 7  $\Rightarrow$  ASCII 37; BCD 5  $\Rightarrow$  ASCII 35). This illustrates the usefulness of PACK and UNPK instructions in code conversions.

|                                                                                                                                                                                                                                                                                                | displa                                                                                                                                                                                                                                                                                                                                                                                                      | cement                        | bits<br>b7          | b6                      | b5                    | b4                  | b3                    | b2                   | bl                   | ь0                    |              |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|---------------------|-------------------------|-----------------------|---------------------|-----------------------|----------------------|----------------------|-----------------------|--------------|
| byte address 400                                                                                                                                                                                                                                                                               | 7                                                                                                                                                                                                                                                                                                                                                                                                           | -8                            | 1                   | 0                       | 1                     | 1                   | ļ                     | 1                    | 0                    | 0                     | \$BC         |
| base byte address 400<br>byte address 400                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                             | 0<br>+8                       | 1<br>0              | 1<br>0                  | 0<br>0                | 1<br>1              | 0<br>0                | 0<br>1               | 0<br>0               | 1<br>1                | \$D1<br>\$15 |
| 1. <b>BFTST 4008</b> $\{2:6\}$<br>Tests bit field with<br>tion 4008. N = 0 (                                                                                                                                                                                                                   | base ad                                                                                                                                                                                                                                                                                                                                                                                                     | dress 40<br>5 is 0); 2        | 108, off<br>Z = 0 ( | iset 2 au<br>(bit field | nd widt<br>I is not   | h 6 bits<br>1zero). | . Tests               | bits b5              | b0 of                | byte at               |              |
| 2. BFCLR 4008{2:6}<br>Performs BFTST o<br>bits b5-b0 of byte<br>the N and Z values                                                                                                                                                                                                             | peration<br>at 4008                                                                                                                                                                                                                                                                                                                                                                                         | as abov<br>. (If BF           | e first a<br>SET is | and retu<br>used, t     | irns the<br>hen the   | N and<br>corresp    | Z value<br>conding    | es (O an<br>bits are | id 0). T<br>e set af | 'hen cle<br>ter retur | ars          |
| 3. BFCHG 4008{2:6}<br>After performing the<br>gles (1 to 0 and 0 t                                                                                                                                                                                                                             | e BFTS                                                                                                                                                                                                                                                                                                                                                                                                      | T opera<br>s b5-b0            | tion as<br>of byte  | above a<br>e 4008.      | and reta              | urning t            | he N an               | id Z val             | lues (O              | and 0),               | tog-         |
| Extracts bit field with (moves) b7-b0 bits b7-b0 of byte                                                                                                                                                                                                                                       | 4. BFEXTU 4008(-8:16),D1:<br>Extracts bit field with base address 4008, offset -8, and width 16 bits. In this case, it extracts (moves) b7-b0 bits of byte at 4008 into b7-b0 bit positions of the D1 register. It further moves bits b7-b0 of byte at 4007 into bit positions b15-b8 of the D1 register. The rest of the bits of the D1 register are loaded with zeros, since the instruction is unsigned. |                               |                     |                         |                       |                     |                       |                      |                      |                       |              |
|                                                                                                                                                                                                                                                                                                | N =                                                                                                                                                                                                                                                                                                                                                                                                         | \$000<br>1 (MSI<br>0 (non:    | B of the            | e bit fie               |                       | of byte             | at 4007               | ) = 1)               |                      |                       |              |
| If BFEXTS (signed higher bits of the de                                                                                                                                                                                                                                                        | extract<br>stinatio                                                                                                                                                                                                                                                                                                                                                                                         | instructi<br>n registe        | on) is u<br>r. Thus | used, th<br>s, BFE2     | e MSB<br>XTS 4        | bit of<br>1008{-1   | the bit f<br>8:16} yi | ield is :<br>íelds   | sign ex              | tended (              | to the       |
|                                                                                                                                                                                                                                                                                                | DI = \$ F F F F B C D I<br>N = I<br>Z = 0                                                                                                                                                                                                                                                                                                                                                                   |                               |                     |                         |                       |                     |                       |                      |                      |                       |              |
| 5. BFINS D1,4008{12:4}: $(D1 = \$ F F F B C D 1)$<br>Inserts into bit field with base address 4008, offset 12 the last 4 bits of the D1 register. In this case, 0 0 0 1 bits are inserted in bit positions b3-b0 of byte at 4009. N = 0 and Z = 0, since a positive nonzero value is inserted. |                                                                                                                                                                                                                                                                                                                                                                                                             |                               |                     |                         |                       |                     |                       |                      |                      |                       |              |
| 6. BFFFO 4008{8:8<br>Finds first one in the<br>Returns the effective<br>byte at 4009. This c                                                                                                                                                                                                   | e specifi<br>offset                                                                                                                                                                                                                                                                                                                                                                                         | value to                      | the D2              | registe                 | r. In th              | is case.            | , the firs            | 8 and f<br>st one i  | îeld wi<br>s found   | dth 8 bi<br>1 at b4 c | its.<br>of   |
|                                                                                                                                                                                                                                                                                                | Ν                                                                                                                                                                                                                                                                                                                                                                                                           | = \$ 0 (<br>= 1 (1<br>= 0 (no | found i             | n the s                 | pecified<br>e bit fie | l bit fiel<br>eld)  | d as M                | SB)                  |                      |                       |              |

.....

20

FIGURE 11.12 Bit-field instruction applications.

# Other Instructions and Enhancements

In the 68020, the divide and multiply instructions are extended to cover 32-bit operands. The TRAP instructions are further extended to operate on condition (TRAPcc). The CAS (compare and swap) instructions are of the read-modify/write type and enhance system throughput. There are also a set of coprocessor instructions (cpxxx) to control the coprocessor operation. Figure 11.13 summarizes the 68020 instruction set.

The 68020 processor has an internal 4-word pipe that holds the prefetched instructions and operands. The pipe is filled whenever there is a two-word vacancy. In the case of a change in program flow, the pipe contents are invalidated and the pipe is refilled.<sup>6</sup>

## 11.3 CACHE MEMORY CONCEPTS AND ORGANIZATION

**Cache memory** is a fast-access, high-speed memory designed to hold the most frequently used information. The processor copies the required information from the main memory into the cache memory. The cache memory is usually of limited size. As often as is necessary, the cached information is updated.

# 68020 Cache Memory Organization and Operation

The 68020 processor has a 256-byte instruction cache memory on the chip, itself. It is organized as 64 long words, as shown in Figure 11.14. Two internal registers, the CACR (cache control register) and the CAAR (cache address register), determine the operation of the cache memory. The cache memory can be disabled or enabled. When enabled, the processor fills in the cache memory with the most recently fetched instructions and uses them.

When the processor wants to fetch an instruction, it checks the cache memory to determine whether the instruction is in the cache. If it is in the cache, we have what is known as a hit condition. If it is not in the cache, we have what is known as a miss condition.

For a hit condition, the processor fetches the instruction from the cache and executes it. The typical instruction access time from cache corresponds to two clock cycles. For a miss condition, the processor fetches the instruction from the external memory and executes it. The typical instruction access time from external memory corresponds to three clock cycles. Cache memory is always updated with the most recent instructions fetched from the external memory. Figure 11.15 indicates timing under cache hit and cache miss conditions.

When the processor is obtaining instructions from the cache memory and executing them, the external bus is free. The bus interface unit accesses data operands during this time window. In addition, the prefetch mechanism of the 68000 family is operational, even with the cache memory. All of these parallel operations enhance the overall throughput of the 68020 processor.

| Mnemonic                                                                                            | Description                                                                                                                                                                                 | Mnemonic   | Description                           |
|-----------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|---------------------------------------|
| ABCD                                                                                                | Add Decimal with Extend                                                                                                                                                                     | MULS       | Signed Multiply                       |
| ADD                                                                                                 | Add                                                                                                                                                                                         | MULU       | Unsigned Multiply                     |
| ADDA                                                                                                | Add Address                                                                                                                                                                                 | NBCD       | Negate Decimal with Extend            |
| ADDI                                                                                                | Add Immediate                                                                                                                                                                               | NEG        | Negate                                |
| ADDO                                                                                                | Add Quick                                                                                                                                                                                   | NEGX       | Negate with Extend                    |
| ADDX                                                                                                | Add with Extend                                                                                                                                                                             | NOP        | No Operation                          |
| AND                                                                                                 | Logical AND                                                                                                                                                                                 | NOT        | Logical Complement                    |
| ANDI                                                                                                | Logical AND Immediate                                                                                                                                                                       | OR         | Logical Inclusive OR                  |
| ASL, ASR                                                                                            | Arithmetic Shift Left and Right                                                                                                                                                             | ORI        | Logical OR Immediate                  |
| Bcc                                                                                                 | Branch Conditionally                                                                                                                                                                        | PACK       | Pack BCD                              |
| BCHG                                                                                                | Test Bit and Change                                                                                                                                                                         | PEA        | Push Effective Address                |
| BCLR                                                                                                | Test Bit and Clear                                                                                                                                                                          | RESET      | Reset External Devices                |
| BFCHG                                                                                               | Test Bit Field and Change                                                                                                                                                                   | ROL, ROR   | Rotate Left and Right                 |
| 8FCLR                                                                                               | Test Bit Field and Clear                                                                                                                                                                    | ROXL, ROXR |                                       |
| BFEXTS                                                                                              | Signed Bit Field Extract                                                                                                                                                                    | RTD        | Return and Deallocate                 |
| BFEXTU                                                                                              | Unsigned Bit Field Extract                                                                                                                                                                  | RTE        | Return from Exception                 |
| BFFFO                                                                                               | Bit Field Find First One                                                                                                                                                                    | RTM        | Return from Module                    |
| BFINS                                                                                               | Bit Field Insert                                                                                                                                                                            | RTR        | Return and Restore Conditon Codes     |
| BFSET                                                                                               | Test Bit Field and Set                                                                                                                                                                      | RTS        | Return from Subroutine                |
| BFTST                                                                                               | Test Bit Field<br>Branch                                                                                                                                                                    | SBCD       | Subtract Decimal with Extend          |
| BRA                                                                                                 | Branch<br>Test Bit and Set                                                                                                                                                                  | Scc        | Set Conditionally                     |
| 8SET<br>BSR                                                                                         | First Bit and Set<br>Branch to Subroutine                                                                                                                                                   | STOP       | Stop                                  |
| BIST                                                                                                | Test Bit                                                                                                                                                                                    | SUB        | Subtract                              |
|                                                                                                     |                                                                                                                                                                                             | SUBA       | Subtract Address                      |
| CALLM                                                                                               | Call Module                                                                                                                                                                                 | SUBI       | Subtract Immediate                    |
| CAS                                                                                                 | Compare and Swap Operands                                                                                                                                                                   | SUBQ       | Subtract Quick                        |
| CAS2<br>CHK                                                                                         | Compare and Swap Dual Operands                                                                                                                                                              | SUBX       | Subtract with Extend                  |
| снк<br>Снк2                                                                                         | Check Register Against Bound<br>Check Register Against Upper and                                                                                                                            | SWAP       | Swap Register Words                   |
| UNKZ                                                                                                | Lower Bounds                                                                                                                                                                                | TAS        | Test Operand and Set                  |
| CLR                                                                                                 | Clear                                                                                                                                                                                       | TRAP       | Тгар                                  |
| CMP                                                                                                 | Compare                                                                                                                                                                                     | TRAPcc     | Trap Conditionally                    |
| CMPA                                                                                                | Compare Address                                                                                                                                                                             | TRAPV      | Trap on Overflow                      |
| CMPI                                                                                                | Compare Immediate                                                                                                                                                                           | TST        | Test Operand                          |
| СМРМ                                                                                                | Compare Memory to Memory                                                                                                                                                                    | UNLK       | Unlink                                |
| CMP2                                                                                                | Compare Register Against Upper and                                                                                                                                                          | UNPK       | Unpack BCD                            |
|                                                                                                     | Lower Bounds                                                                                                                                                                                |            | DOOCCOOD INGTRUCTIONS                 |
| DBcc                                                                                                | Test Condition, Decrement and Branch                                                                                                                                                        |            | PROCESSOR INSTRUCTIONS                |
| DIVS, DIVSL                                                                                         | Signed Divide                                                                                                                                                                               | cp8cc      | Branch Conditionally                  |
| DIVU, DIVUL                                                                                         | Unsigned Divide                                                                                                                                                                             | cpDBcc     | Test Coprocessor Condition,           |
| EOR                                                                                                 | Logical Exclusive OR                                                                                                                                                                        |            | Decrement, and Branch                 |
| EORI                                                                                                | Logical Exclusive QR Immediate                                                                                                                                                              | cpGEN      | Coprocessor General Instruction       |
| EXG                                                                                                 | Exchange Registers                                                                                                                                                                          | cpRESTORE  | Restore Internal State of Coprocessor |
| EXT                                                                                                 | Sign Extend                                                                                                                                                                                 | COSAVE     | Save Internal State of Coprocessor    |
| JMP                                                                                                 | gmu                                                                                                                                                                                         | cpScc      | Set Conditionally                     |
| JSR                                                                                                 | Jump to Subroutine                                                                                                                                                                          | cpTRAPcc   | Trap Conditionally                    |
|                                                                                                     | Load Effective Address                                                                                                                                                                      |            |                                       |
| LEA                                                                                                 |                                                                                                                                                                                             |            |                                       |
| lea<br>Link j                                                                                       | Link and Allocate                                                                                                                                                                           |            |                                       |
|                                                                                                     |                                                                                                                                                                                             |            |                                       |
| LINK                                                                                                | Link and Allocate<br>Logical Shift Left and Right<br>Move                                                                                                                                   |            |                                       |
| LINK<br>LSL, LSR                                                                                    | Logical Shift Left and Right                                                                                                                                                                |            |                                       |
| LINK<br>LSL, LSR<br>MOVE                                                                            | Logical Shift Left and Right<br>Move<br>Move Address                                                                                                                                        |            |                                       |
| LINK<br>LSL, LSR<br>MOVE<br>MOVEA<br>MOVE CCR<br>MOVE SR                                            | Logical Shift Left and Right<br>Move                                                                                                                                                        |            |                                       |
| LINK<br>LSL, LSR<br>MOVE<br>MOVEA<br>MOVE CCR<br>MOVE SR<br>MOVE USP                                | Logical Shift Left and Right<br>Move<br>Move Address<br>Move Condition Code Register                                                                                                        |            |                                       |
| LINK<br>LSL, LSR<br>MOVE<br>MOVEA<br>MOVE CCR<br>MOVE SR<br>MOVE USP<br>MOVEC                       | Logical Shift Left and Right<br>Move<br>Move Address<br>Move Condition Code Register<br>Move Status Register                                                                                |            |                                       |
| LINK<br>LSL, LSR<br>MOVE<br>MOVE CCR<br>MOVE CCR<br>MOVE SR<br>MOVE USP<br>MOVEC<br>MOVEM           | Logical Shift Left and Right<br>Move<br>Move Address<br>Move Condition Code Register<br>Move Status Register<br>Move User Stack Pointer                                                     |            |                                       |
| LINK<br>LSL, LSR<br>MOVE<br>MOVE CCR<br>MOVE CCR<br>MOVE CCR<br>MOVE USP<br>MOVEC<br>MOVEM<br>MOVEP | Logical Shift Left and Right<br>Move<br>Move Address<br>Move Condition Code Register<br>Move Status Register<br>Move User Stack Pointer<br>Move Control Register                            |            |                                       |
| LINK<br>LSL, LSR<br>MOVE<br>MOVE CCR<br>MOVE CCR<br>MOVE SR<br>MOVE USP<br>MOVEC<br>MOVEM           | Logical Shift Left and Right<br>Move<br>Move Address<br>Move Condition Code Register<br>Move Status Register<br>Move User Stack Pointer<br>Move Control Register<br>Move Multiple Registers |            |                                       |

FIGURE 11.13 Instruction set summary for the 68020. (Courtesy of Motorola, Inc.)



FIGURE 11.16 (a) Cache control register (CACR) and (b) cache address register (CAAR) formats of the 68020.



b31

FIGURE 11.14 The 68020 cache memory organization and operation.

# Cache Control and Cache Address Registers

The cache memory operation is controlled by the cache control (CACR) and cache address (CAAR) registers. These are illustrated in Figure 11.16. Using the CACR, the cache memory can be disabled or enabled, the cache entry can be cleared or frozen, or the cache memory can be completely cleared. These operations are required during initialization or when the processor is changing tasks.

The 6-bit index field of the CAAR specifies one of the 64 long words of the cache memory. The 24-bit tag, filed along with FC2 function code bit, specifies the address



FIGURE 11.15 Cache hit and cache miss timing of the 68020. (Courtesy of Motorola, Inc.)

tag field of the instruction. FC2 is required to distinguish between supervisor and user space. In addition, there is a V bit associated with each of the address tag fields in the cache memory address area. If the V bit is 1, the corresponding cached instruction is valid.

At power-up reset, the CACR is cleared to the all-zero condition and the cache is disabled. The cache needs to be properly initialized as a part of the system reset routine. The cache registers CACR and CAAR can be accessed only in the supervisor mode (using the MOVEC instruction).

Sometimes it is necessary to hardware disable the cache memory for debugging purposes. This is accomplished by activating the CDIS signal to a low level, as shown in Figure 11.14.

We will now present an example problem to review what we have learned about cache memory.

Example 11.2 68020 cache memory and performance. Consider a 68020-based system.

- 1. Why is the cache memory disabled on power-up reset?
- 2. How much additional tag address and other space is required for each long-word cache entry?

3. Assume the following code is being executed while the cache memory is disabled:

| MOVE.L<br>ADD.L | (54)<br>(50 |
|-----------------|-------------|
| NOP             | DE,         |
| MOVE.L          | DD,         |

|                                                                                                                                                                                                                            | b4                                                                                | <b>b</b> 3 | b2 | <b>b</b> 1                                               | <b>b</b> 0 |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|------------|----|----------------------------------------------------------|------------|--|--|
|                                                                                                                                                                                                                            | •• 0                                                                              | с          | CE | F                                                        | Е          |  |  |
| C ⇒ Clear cache<br>⇒ Clear entry<br>⇒ Freeze cache<br>t ⇒ Enable cache<br>(1 clears all cache entries)<br>(1 clears the CAAR specified entry)<br>(1 freezes cache entry and update)<br>(1 enables the cache memory)<br>(a) |                                                                                   |            |    |                                                          |            |  |  |
| b8                                                                                                                                                                                                                         | b7                                                                                |            | b2 | ы                                                        | 60         |  |  |
| Tag                                                                                                                                                                                                                        | In                                                                                | dex        | T  | Blo                                                      | ck         |  |  |
| address tag field<br>the address tag of<br>etion corresponding<br>. A8 address lines<br>(b)                                                                                                                                | 6-bit index<br>field specifies<br>I out of 64<br>long words<br>in cache<br>memory |            |    | 2-bit<br>field<br>specifies<br>upper or<br>lower<br>word |            |  |  |

50,+( DD

(A3)+

With 32-bit aligned access, how many total read and write bus cycles take place on the external bus, including the instruction prefetches? 4. Answer the preceding question, assuming the cache is enabled and the code is in the cache memory.

#### Solution

- 1. Cache disable on reset: The information contained in the cache memory at the time of power-up reset does not correspond to any valid code. The cache memory should be disabled to prevent the processor from running invalid code from it.
- 2. Additional cache space: Each long-word cache entry has a 25-bit effective tag address field (A31-A8 and FC2 values). Each long-word entry also has an associated V bit. Thus, 26 bits of additional cache space is required for each long-word entry.
- 3. Bus cycles when cache is disabled: Each of the instructions is a single op.word instruction. To prefetch four op.words, two read bus cycles are required on the 32-bit aligned access. In addition, the instruction MOVE.L (A2)+,D2 requires a read cycle to obtain the source operand and the instruction MOVE.L D0,(A3)+ requires a write bus cycle to write the destination operand. Thus, the total number of bus cycles required is four.
- 4. Bus cycles when cache is enabled: When the instructions are already in the cache and the cache memory is enabled, the instruction fetches will be from the cache. The external bus activity is only for the source and the destination operands. Thus, the total number of bus cycles required is two.

In the preceding example, the benefits of the cache memory and aligned access are apparent. The external bus cycles are greatly reduced, enhancing the throughput. However, depending upon the alignment, the port size, and the cache memory condition, actual bus activity varies.

# 11.4 GENERAL ARCHITECTURE OF THE 68030

The 68030 is an enhanced 32-bit microprocessor contained in a 128-pin grid-array package. It is fabricated with VLSI HMOS technology. It has all the resources of the 68020 processor. In addition, it contains the data cache and the memory management units on the chip.<sup>7</sup>

#### Instruction and Data Cache Memory Organization

The 68030 processor contains a 256-byte instruction cache memory and a separate 256- byte data cache memory on the chip. The instruction cache is similar to that of the -68020 processor, but is organized as a bank of 16 rows of 4 long words. There are 16 address tag fields for the 16 rows, consisting of FC2 output and address lines A31-A8. ---



Selection of one of the 16 rows of the cache bank is accomplished by address lines A7-A4. Selection of one of the long words of a row is accomplished by the A3 and A2 address lines. The Al address line is used to select the upper or lower word within a long word. Each long word is associated with a V bit. The operation of the 68030 instruction cache is similar to that of the 68020 processor.

Data cache organization in the 68030 is similar to instruction cache organization. In the address tag field, however, the FC1 and FC0 function code bits are also included. The processor reads the cached data in the case of a hit condition. When there is a hit condition for writing data, the processor writes the data in the cache memory and also in the external memory. This is necessary to eliminate any stale data in the external data memory.

# Additional Software Resources of the 68030 Processor

Figure 11.17 specifies the register architecture of the 68030 processor. In addition to the 68020 resources, it has extra registers related to the memory management unit (MMU). These registers can be handled only in the supervisor mode. The logical address space for the 68030 is 4 gigabytes. The physical address space depends upon the available hardware and is much less than the logical space. In virtual memory implementation, the MMU translates a logical address into an existing physical address. Associated with the MMU, there is also an address translation cache (ATC) memory on board for the 68030. The ATC has 22 entries consisting of the most recently used address translations.

Whenever there is a requirement for an address translation from a logical address to a physical address, the ATC is checked for a hit. For a hit condition, the cached translation address is used to locate the instruction or the data operand. For a miss condition, 68030 goes to the external memory to locate the address translation tables and obtains the required information.

Figure 11.18 summarizes the functions of the MMU registers and Figure 11.19 summarizes the additional 68030 instructions to support the MMU functions. These MMU instructions are privileged. In Figure 11.20, the relative performance of the 68020 and 68030 processors is indicated.

- $\Rightarrow$  Translation control: Controls the translation process. TC
- CRP  $\Rightarrow$  CPU root pointer: Locates the root pointer in memory for user-level operating systems.
- $\Rightarrow$  Supervisor root pointer: Locates the root pointer in memory for the govern-SRP ing operating system.
- **TTO** and  $\Rightarrow$  **Transparent translation registers 0 and 1:** The entries here will be transparent to the ATC and will not be cached. TT1
- MMUSR > MMU status register: Contains the status of the MMU operations.

FIGURE 11.18 68030 MMU register functions.

|    | PMOVE<br>PLOAD<br>PTEST<br>PFLUSH<br>PFLUSHA | <ul> <li>⇒ Move to and from MMU reg registers and the EA.)</li> <li>⇒ Load page descriptor into the</li> <li>⇒ Test translation. (Tests the A</li> <li>⇒ Flush selected ATC entries at</li> <li>⇒ Flush all ATC entries.</li> </ul> |
|----|----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Fl | GURE 11.19                                   | MMU-related instructions for                                                                                                                                                                                                        |

FIGURE 11.20 Relative performance of the 68020 and 68030 processors.

1.5

# Additional Hardware Resources of the 68030 Processor

In Figures 11.21 and 11.22 the 68030 functional signal groups and associated signal descriptions are given. There are additional cache control signals to assist instruction and data cache management.

The synchronous termination input (/STERM) is of particular importance. It controls synchronous transfers between the processor and the external memory and I/O. Synchronous transfers take only two clock cycles, as compared to three clock cycles for normal asynchronous transfers. The processor terminates the bus cycle upon receiving /STERM. If /STERM is not received, the processor assumes the normal asynchronous operation and looks for the /DSACK signals. In synchronous operation, only 32-bit aligned transfers are allowed. The other hardware resources of the 68030 function in basically the same manner as in the 68020 processor. We will now present an example problem to review what we have learned about the 68030.

# Example 11.3 The 68030 microprocessor. With regard to the 68030 microprocessor,

- 1. why is it useful to have a data cache?
- 2. why is it useful to have the MMU on board?
- 3. what are the disadvantages of the data cache and MMU?

# Solution

Data cache: In the case of a cache hit for read operations, only two clock cycle data transfers are required, as compared to three clock cycle data transfers for external

gisters. (Moves contents between the MMU

e ATC from the EA. ATC and updates the MMU status register.) as specified by the EA.

the 68030.





FIGURE 11.21 Functional signal groups of the 68030. (Courtesy of Motorola, Inc.)

memory access. This increases the throughput by 33.3 percent for read operations. For write operations, since data are also written into the external memory, there is no speed advantage. However, the updated data may be used for other read operations, ultimately resulting in a speed advantage.

- 2. MMU on board: The MMU and the associated ATC provide internal 2-cycle access, as compared to external 3-cycle access. This, in turn, affords a speed advan- tage of 33.3 percent.
- 3. Disadvantages of on-board cache and MMU: Each of the units takes silicon real estate and complicates semiconductor processing. Thus, the cost of the unit is increased. Also, the integrated functionality makes debugging and testing difficult.

Figure 11.23 illustrates the internal structure of the very powerful 68030 processor. As of this writing, considerable system development is still taking place. The concepts we have presented are elementary; for more detailed information, additional references should be consulted.<sup>8,9</sup>

| Signal Name                        | Mnemonic      | Function                                                                                                                                                                                      |
|------------------------------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Function Codes                     | FC0-FC2       | 3-bit function code used to identify the address space of each bus cyc                                                                                                                        |
| Address Bus                        | A0-A31        | 32-bit address bus used to address any of 4,294,967,296 bytes.                                                                                                                                |
| Data Bus                           | D0-D31        | 32-bit data bus used to transfer 8, 16, 24, or 32 bits of data per bus cyc                                                                                                                    |
| Size                               | SIZ0/SIZ1     | Indicates the number of bytes remaining to be transferred for this cyc<br>These signals, together with A0 and A1, define the active sections of t<br>data bus.                                |
| Operand Cycle Start                | OCS           | Identical operation to that of ECS except that OCS is asserted only duri<br>the first bus cycle of an operand transfer.                                                                       |
| External Cycle Start               | ECS           | Provides an indication that a bus cycle is beginning.                                                                                                                                         |
| Read/Write                         | R/₩           | Defines the bus transfer as an MPU read or write.                                                                                                                                             |
| Read-Modify-Write Cycle            | RMC           | Provides an indicator that the current bus cycle is part of an indivisib read-modify-write operation.                                                                                         |
| Address Strobe                     | ĀS            | Indicates that a valid address is on the bus.                                                                                                                                                 |
| Data Strobe                        | DS            | Indicates that valid data is to be placed on the data bus by an extern<br>device or has been placed on the data bus by the MC68030.                                                           |
| Data Buffer Enable                 | ÖBEN          | Provides an enable signal for external data buffers.                                                                                                                                          |
| Data Transfer and Size Acknowledge | DSACK0/DSACK1 | Bus response signals that indicate the requested data transfer operation<br>is completed. In addition, these two lines indicate the size of the extern<br>bus port on a cycle-by-cycle basis. |
| Cache Inhibit In                   | CIIN          | Prevents data from being loaded into the MC68030 instruction and dat caches.                                                                                                                  |
| Cache Inhibit Out                  | CIOUT         | Reflects the CI bit in ATC entries or a transparent translation registe indicates that external caches should ignore these accesses.                                                          |
| Cache Burst Request                | CBREQ         | Indicates a miss in either the instruction or data cache for cachable and cesses.                                                                                                             |
| Cache Burst Acknowledge            | CBACK         | Indicates that accessed device can operate in burst mode.                                                                                                                                     |
| Interrupt Priority Level           | IPLO-IPL2     | Provides an encoded interrupt level to the processor.                                                                                                                                         |
| Interrupt Pending                  | IPEND         | Indicates that an interrupt is pending.                                                                                                                                                       |
| Autovector                         | AVEC          | Requests an autovector during an interrupt acknowledge cycle.                                                                                                                                 |
| Bus Request                        | BR            | Indicates that an external device requires bus mastership.                                                                                                                                    |
| Bus Grant                          | BG            | Indicates that an external device may assume bus mastership.                                                                                                                                  |
| Bus Grant Acknowledge              | BGACK         | Indicates that an external device has assumed bus mastership.                                                                                                                                 |
| Reser                              |               | System reset.                                                                                                                                                                                 |
| Halt                               |               | Indicates that the processor should suspend bus activity.                                                                                                                                     |
| Bus Error                          | BERR          | Indicates an invalid or illegal bus operation is being attempted.                                                                                                                             |
| Synchronous Termination            | STERM         | Bus response signal that indicates a port size of 32 bits and that data may<br>be latched on the next falling clock edge.                                                                     |
| Cache Disable                      |               |                                                                                                                                                                                               |
| MU Disable                         |               | Dynamically disables the on-chip cache to assist emulator support.                                                                                                                            |
| Aicrosequencer Status              |               | Dynamically disables the translation mechanism of the MMU.                                                                                                                                    |
| ipe Refill                         |               | Status indications for debug purposes.                                                                                                                                                        |
| lock                               |               | ndicates when the instruction pipe is beginning to refill                                                                                                                                     |
| ower Supply                        |               | Clock input to the processor.                                                                                                                                                                 |
| round                              | Vcc           | +5 volt ± 5% power supply                                                                                                                                                                     |

FIGURE 11.22 Signal descriptions for the 68030. (Courtesy of Motorola, Inc.)



# 11.5 FUNCTIONAL IMPROVEMENTS IN THE 68020 AND 68030 PROCESSORS

Even (hough the 68020 and 68030 are based on the prototype architecture of the 68000 processor, they far exceed the functional capabilities of the 68000. This is primarily due to their memory indirect addressing capability, extended instructions for 32-bit operand manipulations (such as multiply and divide), cache memory and virtual memory implementation capabilities, and their enhanced 32-bit data and address buses.

For routine 16/32 bit applications, the 68000 processor with 16-megabyte address space is usually sufficient and is widely used. For applications requiring fast operations, large memory space (up to 4-gigabyte), and cache memory implementation schemes, the 68020 and 68030 processors are preferred. If a data cache and memory management are also required, the 68030 is the processor of choice.

# Memory Indirect Addressing Capability

The 68020 and 68030 processors have the additional memory indirect addressing mode as we discussed earlier in the chapter. This addressing mode uses any memory location us a memory pointer register, which provides unlimited pointer resources in addition to the internal registers. The 68000 processor does not have the memory indirect addressing scheme; therefore, it must use one of the seven address registers (A0-A6) for any register indirect addressing scheme.

# 32-Bit Extended Instructions

For the 68020 and 68030 processors, some instructions, such as the multiply (MULU, MULS) and divide (D1VU, DIVS), are extended to handle 32-bit operands, producing a 64-bit result. For the 68000 processor, these instructions operate on 16-bit operands and produce 32-bit results. To obtain a 64-bit effective result with the 68000 processor, a software routine must be written and executed.

# Cache Memory and the Concept of Tag Field

Both the 68020 and 68030 processors have an instruction cache on board, organized as 64 long words as discussed earlier. The 68030 processor has an additional data cache on board. The upper 24-bit address reference (A31-A8) for the instruction cache memory is called the **address tag.** The next 6-bit address reference (A7-A2) is called the **address index**, which selects one out of the 64 cache locations on board.

Bach cache location has a **tag field**, in which tag information is stored, and an **instruction field**, in which information corresponding to the tag field is stored. If a memory reference is made, the stored tag is checked against the current tag for a hit. In the event of a hit, the information from the cache is read by the processor. In the event  $^{\circ}$ f a miss, the processor goes to the external memory, obtains the instruction, copies it into the cache memory, and executes it.

The 68000 and 68010 processors do not have cache memory capability; hence, the tag field concept does not apply to them.

# The 68020 and 68030 Additional Signal Groups

The 68020 and 68030 processors have all the signal groups of the 68000 processor. In the 68020 and 68030, the data bus is extended to 32 bits compared to the 16-bit data bus of the 68000. The address bus is extended to 32 bits compared to the 24-bit effective address bus of the 68000. The control bus of the 68020 and 68030 processors is extended to include two data acknowledge signals (DSACK0 and DSACK1), size signals (SIZ0 and SIZI), and bus interface signals (OCS, ECS, and RMC).

In addition, the 68020 processor has a cache disable (CDIS) input signal. The 68030 has four cache-related signals to handle the data and instruction cache on board. All of these additional resources increase the throughput of the 68020/30-based system.

# Software Considerations for the 68020 and 68030 Processors

The assembly language programming techniques for the 68020 and 68030 processors are similar to those for the 68000. Due to additional and enhanced instructions, the efficiency of the software routines for the 68020 and 68030 processors can be increased. In case of loop-type operations, for example, instructions are copied into the cache memory, which further reduces the execution time of the program.

The following example problem deals with the software capabilities of the 68020 and 68030.

### Example 11.4 68020130-processor software.

Suppose a 68020/30-based system is used in a control system application with a software routine as shown in Figure 11.24.

- 1. Assuming the cache is disabled, analyze the software and specify the contents of the affected registers after the MULU and DIVU instructions.
- 2. Assume that the NOP instruction is replaced by the DBRA D3,AGAIN instruction. Consider the cache to be enabled. How many times is the AGAIN loop run? How many times is the code obtained from the cache memory?
- 3. Can the same software function on a 68000-based system?

## Solution

## 1. Software and contents of the registers: The software initializes

 $A0 \Rightarrow$  \$00004000;  $D0 \Rightarrow$  \$22224444;  $D1 \Rightarrow$  \$00000000  $D2 \Rightarrow$  \$00000000;  $D3 \Rightarrow$  \$\$0000200;  $D4 \Rightarrow$  \$00000200

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ;68020/30                                                                | based                                                               | softwa                                                         |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|---------------------------------------------------------------------|----------------------------------------------------------------|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ,                                                                        | CHIP<br>OPT<br>ORG                                                  | 6<br>A<br>\$                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ;initiali<br>;AO is me<br>;indirect<br>;DO is th                         | ze reg<br>mory p<br>addre                                           | isters<br>ointer<br>ssing                                      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ,<br>START                                                               | MOVEA<br>MOVE.<br>CLR.L<br>CLR.L                                    | L #:<br>D1<br>D3                                               |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ;perform ;<br>multiplic;<br>division<br>all numbe                        | cation<br>is uns                                                    | L D3<br>ord mu]<br>îs uns<br>signed                            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | AGAIN                                                                    | MULU.I<br>DIVU.I<br>MOVE.I<br>NOP                                   | # <b>\$</b>                                                    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                          | JMP                                                                 | ST                                                             |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                          |                                                                     |                                                                |
| 11.4).<br>The M<br>D0 reg                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 11.24 68020/3<br>ULU.L #\$0<br>ister with the<br>r as shown.             | 0000020                                                             | ,D1,D0 i                                                       |
| 11.4).<br>The M<br>D0 reg                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ULU.L #\$0<br>ister with the                                             | 0000020<br>32-bit m                                                 | ,D1,D0 i                                                       |
| <ul> <li>11.4).</li> <li>The M</li> <li>D0 reg</li> <li>D0 pai</li> <li>D0 pai</li> <li>The upper</li> <li>The upper is put in the second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second seco</li></ul> | ULU.L #\$0<br>ister with the<br>r as shown.                              | 0000020<br>32-bit m<br>×\$                                          | ,D1,D0 i<br>nultiplier<br>D0 (befo<br><u>multiplie</u><br>0000 |
| 11.4).<br>The M<br>D0 reg<br>D0 pai                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ULU.L #\$0<br>ister with the<br>r as shown.<br>result<br>8-digit (32-bit | 0000020<br>32-bit m<br>×<br>\$<br>\$<br>) result i<br>Thus, a<br>DI | ,D1,D0 i<br>nultiplier<br>D0 (befo<br><u>multiplie</u><br>0000 |

```
are
0508
0002000
for memory
mode
ter for multiply and divide
$00004000,A0
$222254444,DO
               ;clear D1
              ;clear D2
$00000200,03
3,04
ltiplication and division
signed
lecimal
60000020,D1,D0
$00000100,D2,D0
),([0,A0,D3.W*4],0)
TART
```

e for the control system application (Example

instruction multiplies the 32-bit contents of the \$20, and puts the 64-bit result in the D1 and

| ore) | \$ | 2 | 2 | 2 | 2 | 4 | 4 | 4 | 4 |
|------|----|---|---|---|---|---|---|---|---|
| er   | \$ | 0 | 0 | 0 | 0 | 0 | 0 | 2 | 0 |
| 000  | 4  | 4 | 4 | 4 | 8 | 8 | 8 | 8 | 0 |

the D1 register and the lower 8-digit result multiplication;

# 0000004 488880

tion divides the 64-bit operand contained idend \$00000100. The 32-bit quotient is inder is put in the D2 register, as shown.

| D2 and D0 (before) \$  | 0000000044488880 |
|------------------------|------------------|
| divided by dividend \$ | 00000100         |
| quotient               | \$00444888       |
| remainder              | \$0000080        |

Thus, after the division,

# $D0 \Rightarrow \$00444888$ $D2 \Rightarrow \$0000080$

- 2. DBRA D3,AGAIN instruction: When the NOP is replaced by the DBRA instruction, the software goes into the AGAIN loop until the D3 register is decremented to -1 (from its initial value of \$200). The code is obtained first from the external memory and is copied into the cache. Subsequently, the code is obtained from the cache. Thus, the AGAIN loop is run \$201 times and the code is obtained from the cache \$200 times
- **3.** 68000-based system: The code will not function on the 68000 system, since the 32bit multiply and divide instructions and the memory indirect addressing modes of the software are not defined for the 68000 processor.

# 11.6 SUMMARY

In this chapter we introduced the 68020 and 68030 32-bit microprocessors with onboard cache memory. Both these processors are extensions of the earlier members of the 68000 family. Both have all the resources of the 68010 and 68012 processors. In addition, they have 32-bit address and 32-bit data buses. Both processors also have additional control lines to handle the coprocessor interface.

The 68020 and 68030 have a 4-gigabyte logical address space. They can transfer up to 32 bits of information in one bus cycle. The data bus can be dynamically sized to hold byte, word, or long-word data. This is accomplished by having two data acknowledge signals (/DSACK0 and /DSACK1) and two additional SIZ control signals.

The 68020 has an on-chip 256-byte instruction cache memory organized as 64 long words. The cache memory also contains 64 address tag fields consisting of address lines A31-A8. Whenever a program memory reference is made, the processor examines the address tag entries for a hit condition. In the event of a hit, the processor fetches the instructions from the internal cache. This enhances the overall throughput of the system. In the event of a miss, the processor obtains the instruction code from the external memory for execution and also copies it into the internal cache for subsequent use. A typical cache bus cycle corresponds to two clock cycles, compared to three clock cycles for the external bus cycle for the 68020 and 68030 processors. By contrast, the 68000 takes four clock cycles for a single bus cycle without any wait states.

For the 68020 and 68030 processors, instructions such as multiply and divide are extended to operate on 32-bit operands and provide a 64-bit result. These processors use an addressing scheme known as memory indirect addressing. In this scheme, any valid memory location can serve as a memory pointer. This greatly enhances the addressing capabilities of the 68020 and 68030. There are several variations of the memory indirect addressing scheme.

In our discussion of the bit-field instructions for the 68020 and 68030 processors, we explained how they are used to address bit fields of varying size and operate on them. The 68030 processor is a further enhancement of the 68020 processor. The 68030 has an additional 256-byte data cache memory. To prevent the problem of stale data, whenever new data are written into the cache memory they are also written into the external memory. A speed advantage is realized when the data cache is used for obtaining source operands. The 68030 also has an on-chip memory management unit for implementing address translations and virtual memory schemes. This further increases the

throughput.

The 68020 and 68030 are not pin compatible with one another. Separate hardware must be designed for each. However, they do have similar microcomputer configurations.

# PROBLEMS

- 11.1 Indicate the contents of the system byte of the 68020 processor (a) during power-up system reset;
  - (b) when the processor is servicing interrupt 5 in the supervisor mode: (c) under the conditions of (b), when a bus error condition occurs.
- 11.2 Which stack pointer is used in the 68020
- (b) when the processor is executing user programs? 11.3 State the conditions of the system byte
- used?
- 11.5 What should be the condition of the CDIS signal
  - (a) if the 68020 internal cache is to be disabled continuously? address?
- 11.6 The 68020 has the memory map given in Figure 11.25. the following instructions are executed individually:

(a) when the processor is executing a reset system routine? (a) when an interrupt 7 routine is being executed and there is a trace on each instruction; (b) when a bus error routine is being executed with a trace on change of flow, 11.4 What is the functional difference between the  $\overline{\text{ECS}}$  and  $\overline{\text{OCS}}$  signals? Where are they (b) if the 68020 internal cache is to be disabled for instruction fetches above a certain Specify the conditions of the DSACKx and SIZx signals and the data bus activity when

(a) MOVE.L (A1),D1: AI = \$0000FFFF; long word is \$1234AABB (b) ADD,L (A1),D1: A1 = \$0000FFFF; tong word is \$1234AABB

(c) ADD.L D1,D2: D1 =\$1234AABB; D2 =\$FFFFFFFF (d) MOVE.L D2,(A4): D2 =\$FFFFFFFFF; A4 = \$01010001

(a) BFTST 4008{6:8} main memory (32-bit wide) ⇒\$00000000 to \$00FFFFFF (b) BFCLR 4008{8:6} (c) BFSET 4008{8:6} system I/O (16-bit wide) ⇒\$01000000 to \$0100FFFF (8-bit wide) ⇒\$01010000 to \$010103FF FIGURE 11.25 Memory and I/O map (for Problem 11.6). displacement 11.7 Repeat Problem 11.6, assuming that the instructions are executed in sequence, as a base address 4008 ⇒ program. 11.8 If the VBR is loaded with \$00003000 as a part of a reset routine, specify where the autovectors are located for interrupts 6 and 2. 11.9 Consider the initial conditions given in Figure 11.26. FIGURE 11.27 Bit-field memory map (for Problem 11.13). Indicate the effective address and the data operand in each of the following individual operations: (a) MOVE.W (08,A3,D1.L\*8),D4 (b) MOVEP.L (08,A3,D1.L\*4),D5 (a) BFCHG 4009{7:7} (b) BFEXTU 4008{-16:22},D1 (c) BFEXTS 4008{-16:22},D1 A0 =\$0000ABCD; D0 =\$00000004; \$00004800 0000 11.15 Repeat Problem 11.14 for the following: A1 = \$00000008; D1 = \$00000200; 4802 4802 (a) BFINS  $D4,4007\{12:12\}$ ; D4 = \$047689ABA2 =\$00003000; D2 =\$0000F0F0; 4804 0000 (**b**) BFFFO 4006{5:12},D5 4806 4806 A3 =\$00004000; D3 =\$012A46AB;  $\mathbf{D4} = \$ \mathbf{x} \mathbf{x} \mathbf{x} \mathbf{x} \mathbf{x} \mathbf{x} \mathbf{2} \mathbf{1}.$ \$0000A000 0000 A002 | A002 (a) PACK D3, D5, #\$0000 (b) PACK D3, D5, #\$1010 • . 24 (c) UNPK D4,D5,#\$3030 FIGURE 11.26 Initial conditions (for Problem 11.9). in the D5 register. 11.10 Use the initial conditions of Figure 11.26. Indicate the results of the following operations: (a) ADD.L ([\$1800,A3],D1.W,\$0400),D2 (b) ADD.L ([\$1800,A3,D0.W\*8],\$0A00),D0 11.11 Write appropriate instructions to move long-word contents from location \$00008000 to Assume a 32-bit memory port. the D6 register using each of the following addressing modes and proper displacement values: (a)  $EA \Rightarrow (bd, A0, D0, W^*8)$ (b)  $EA \Rightarrow ([\$6000,A3],D2,W,od)$ 

11.12 Repeat Problem 11.11 using all possible addressing modes. Use A3 as the ARI register and D1 as the index register.

11.13 Consider the bit-field memory values given in Figure 11.27. Specify the operation for each of the following, including the results of the operation and

| 65 | Ь4 | b3 | b2 | 61 | b0 |      |
|----|----|----|----|----|----|------|
| 0  | 0  | 0  | 0  | 0  | 1  | \$01 |
| 1  | ι  | 1  | 1  | 0  | 0  | \$BC |
| 0  | 1  | 0  | 0  | 0  | 1  | \$Di |
| 0  | 1  | 0  | 1  | 0  | 1  | \$15 |
| 1  | 1  | 1  | 0  | 0  | 1  | \$79 |
|    |    |    |    |    |    |      |

bits

b7

0

1

1

0

0

-16

-8

0

+8

+16

Loop

BFTST

BNE

RTE

\_h6

Ω 0

0

1

the contents of the XNZVC flags:

11.14 Using the bit map of Figure 11.27, specify the operation for each of the following, including the results of the operation and the contents of the XNZVC flags:

**11.16** Perform the following PACK and UNPK operations. Initially, D3 = x x x x 4 8 4 3;

11.17 D3 = x x x x 4 8 4 3; D4 = \$ x x x x x 2 1. Write a sequence of instructions, using PACK and UNPK, to pack the number in D3, convert it into an ASCII code, and place it

11.18 Suppose it is required to clear an instruction cache entry at address \$0010004C for the 68020 processor. What are the contents of the CACR and CAAR registers? 11.19 What would happen if the CAAR and CACR were addressed in the user mode? Why? 11.20 The following interrupt routine is being run by the 68020 processor. A4 =\$0000A000.

> MOVEP.L (\$0400,A4),D4 ADD.L #\$00000200,D4 (A4){0:17} Loop

Consider the cache memory is disabled. Indicate the total number of bus cycles, including instruction prefetches, required to execute the preceding program.

- 11.21 Repeat Problem 11.20, assuming the cache memory is enabled.
- 11.22 Explain the concept of stale data. How does stale data affect system performance?
- 11.23 Suppose the program of Problem 11.20 is run on a 68030-based system with the instruction and the data cache units disabled. Compute the total number of bus cycles under the following conditions:
  - (a) asynchronous memory interface;
  - (b) synchronous memory interface.
- 11.24 Repeat Problem 11.23, assuming the instruction and data cache units are enabled.
- 11.25 List three areas in which the 68030 processor can outperform the 68020 processor.
- 11.26 In the software of Figure 11.24, what is the effective address of the operand in the MOVE.L D0,([0,A0,D3.W\*4].0) operation?
- 11.27 What are the contents of the affected registers in Example 11.4 if the MULU and DIVU instructions are replaced by the MULS and DIVS instructions when the AGAIN loop is run the first time?

#### **ENDNOTES**

- 1. Motorola, Inc. MC68020 32-Bit Microprocessor User's Manual. Phoenix, AZ: Motorola Technical Operations, 1987.
- 2. Motorola, Inc. MTT20 68020 Course Notes, Phoenix, AZ: Motorola Technical Operations, 1988.
- 3. Motorola, Inc. MC68020 Technical Summary, Austin, TX: Motorola Microprocessor Group, 1984.
- 4. Miller, M.A. "MC68020 32-Bit Processor." Chap. 11 in The 68000 Microprocessor: Architecture, Programming, and Applications. Columbus, OH: Merrill, 1988.
- 5. MacGregor, D.; Mothersole, D.; and Moyer, B. "The Motorola 68020." IEEE Micro 4(4):101-118.
- 6. Beims, B. Multiprocessing Capabilities of the 68020 32-Bit Microprocessor. App. Note #AR 220. Austin, TX: Motorola Microprocessor Group, 1984.
- 7. Motorola, Inc. MC68030 32-Bit Microprocessor User's Manual. Phoenix, AZ: Motorola Technical Operations, 1988.
- 8. Motorola, Inc. MC68030 Technical Summary. Austin, TX: Motorola Microprocessor Group, 1986.
- 9. Motorola, Inc. Performance Report: 68020 and 68030 32-Bit Microprocessors. App. Note #BR 705/D. Phoenix, AZ: Motorola Technical Operations, 1988.

The digital field deals with the binary number system in which any number is expressed to the base 2 as a string of binary ones and zeros. The most popular number system is the decimal system, in which any number is expressed to the base 10. The binary numbers can be further expressed in the form of hex codes.

#### BINARY AND HEX NUMBER SYSTEMS

A binary number is expressed as a collection of 1s and 0s. Each digit to the left is multiplied by the corresponding power of two. The addition of these values results in the appropriate value for the number string.

> MSB: Most Significant Bit LSB: Least Significant Bit

#### Conversion from Binary to Decimal and Hex Decimal Systems

| bit position<br>(MSB)<br>binary value | 7<br>0 | 6<br>0 | 5<br>1<br>2 <sup>5</sup> | 4<br>1<br>24 | 3<br> <br>2 <sup>3</sup> | 2<br>0 | 1 | 0 | (LSB)        |
|---------------------------------------|--------|--------|--------------------------|--------------|--------------------------|--------|---|---|--------------|
|                                       | 0      | ;<br>0 | -<br>32                  | -<br>16      | 8                        | 0      | 2 | Ì | ⇒ 59 decimal |

Expressing larger binary strings can be very tedious. Four binary bits are grouped together to form a hex (or hexadecimal) code or a BCD (binary coded decimal) as

#### APPENDIX



## **Number Systems: Binary** and BCD Operations

| Decimal |   | Binary | Number         |                | Hex Number | BCD Number |  |
|---------|---|--------|----------------|----------------|------------|------------|--|
| Number  |   |        | b <sub>1</sub> | b <sub>0</sub> | Code       | Code       |  |
| 0       | 0 | 0      | 0              | 0              | 0          | 0          |  |
| L       | 0 | 0      | 0              | 1              | 1          | 1          |  |
| 2       | 0 | 0      | 1              | 0              | 2          | 2          |  |
| 3       | 0 | 0      | 1              | 1              | 3          | 3          |  |
| 4       | 0 | 1      | 0              | 0              | 4          | 4          |  |
| 5       | 0 | 1      | 0              | 1              | 5          | 5          |  |
| 6       | 0 | 1      | 1              | 0              | 6          | 6          |  |
| 7       | 0 | 1      | 1              | 1              | 7          | 7          |  |
| 8       | 1 | 0      | 0              | 0              | 8          | 8          |  |
| 9       | Į | 0      | 0              | 1              | 9          | 9          |  |
| 10      | i | 0      | i i            | 0              | А          | Х          |  |
| 11      | 1 | 0      | i              | 1              | B          | Х          |  |
| 12      | 1 | I      | 0              | 0              | С          | Х          |  |
| 13      | 1 | 1      | 0              | 1              | D          | Х          |  |
| 14      | 1 | 1      | ١              | 0              | E          | х          |  |
| 15      | 1 | 1      | 1              | 1              | F          | Х          |  |

TABLE A.1 Decimal, Binary, Hex, and BCD Number Systems

X => invalid code.

shown in Table A.1. The hex code goes from 0 to F for decimal numbers 0 to 15. The BCD code is valid for decimal numbers 0 to 9, as shown.

Binary number

## 00111011 3 B

is equivalent to hex decimal value 3B, as shown. We will use a dollar sign (\$) to represent the hex numbers.

Conversion from Decimal to Hex Decimal and Binary Systems By successively dividing the decimal number by the descending powers of 16, it is possible to obtain the hex decimal number as shown.

16 59 \$3 (quotient)  

$$\frac{48}{11} \Rightarrow$$
 \$B (remainder)

Decimal value 59 is equal to \$3B. Converting \$3B to the binary number is relatively easy and is given by

$$3B \Rightarrow 0 \ 0 \ 1 \ 1 \ 1 \ 0 \ 1 \ 1$$

Binary and Hex Decimal Arithmetic Operations The binary and hex addition and subtraction operations are similar to decimal operations involving carry and borrow concepts. In the binary arithmetic operations, the following identities are used:

0 + 0 = 0; 0 + 1 = 1; 1 + 0 = 1; 1 + 1 = 0 with carry; 0 - 0 = 0; 0 - 1 = 1 with borrow; 1 - 0 = 1; 1 - 1 = 0.

In hex decimal arithmetic, when the sum of addition exceeds a value of 16, carry to the next higher hex digit results. Similarly, borrow from the next higher hex digit results in the case of subtraction. The value of borrow to the lower digit equals 16.

#### Examples

£

Addition of \$FB and \$3A using the hex and binary arithmetic:

$$\begin{array}{c} \$ F B \Rightarrow 11\\ \underline{\$ 3 A} \Rightarrow 00\\ \$ 135 \Rightarrow 100\\ \vdots\\ carry carry \end{array}$$

Subtraction of \$3A from \$2B using the hex and binary arithmetic:

| \$2B   | $\Rightarrow 00$ |
|--------|------------------|
| \$3A   | $\Rightarrow$ 00 |
| \$   F | 111              |
|        | 1                |
| borrow | borrow           |

Multiplication of \$3A by \$03 using the hex and binary arithmetic:

|     | ج ۱ | > | 0                                             | 0                                       | 1                                                            |                                                                      |
|-----|-----|---|-----------------------------------------------|-----------------------------------------|--------------------------------------------------------------|----------------------------------------------------------------------|
|     |     | > | _                                             |                                         |                                                              |                                                                      |
| A I | 3   |   | 0                                             | 0                                       | 1                                                            |                                                                      |
|     |     | 0 | 0                                             | 1                                       | 1                                                            |                                                                      |
|     |     | 0 | l                                             | 0                                       | 1                                                            | (                                                                    |
|     |     |   | $\frac{3}{A E} \Rightarrow \underbrace{0}{2}$ | $\frac{3}{A E} \Rightarrow \frac{1}{0}$ | $\begin{array}{c} 3 \Rightarrow \\ \hline 0 0 1 \end{array}$ | $3 A \Rightarrow 001$ $3 \Rightarrow 001$ $A E = 0011$ $0011$ $0101$ |

Binary multiplication involves successive left-shift and addition operations, as shown. Hex multiplication is similar to decimal multiplication and is simpler than binary multiplication. The hex division operation is similar to decimal division and is left to the reader to practice.

111011 111010 110101

101011 111010 110001

tu ar rutha ri tatata a tin

## APPENDIX

C

# Analog and Digital Converter Devices for Interface

# ADC081 DC0816,

đ

#### **Analog-to-Digital Converters**

# National Semiconductor

#### ADC0816, ADC0817 8-Bit $\mu$ P Compatible A/D Converters with 16-Channel Multiplexer

#### **General Description**

The ADC0816, ADC0817 data acquisition component is a monolithic CMOS device with an 8-bit analog-to-digital converter, 16-channel multiplexer and microprocessor competible control logic. The 8-bit A/D converter uses successive approximation as the conversion technique. The converter features a high impedance chopper stabilized comparator, a 256R voltage divider with analog switch tree and a successive approximation register. The 16-channel multiplexer can directly access any one of 16-singleended analog signals, and provides the logic for addi- Single supply - 5 Voc tional channel expansion. Signal conditioning of any analog input signal is eased by direct access to the multiplexer output, and to the input of the 8-bit A/D converter.

The device eliminates the need for external zero and fullscale adjustments. Easy interfacing to microprocessors is provided by the latched and decoded multiplexer address inputs and latched TTL TRI-STATE® outputs.

The design of the ADC0816, ADC0817 has been optimized by incorporating the most desirable aspects of several A/D conversion techniques. The ADC0816, ADC0817 offers high speed, high accuracy, minimal temperature dependence, excellent long-term accuracy and repeatability, and consumes minimal power. These features make this device ideally suited to applications from process and machine control to consumer and automotive applica. 

Direct access to "comparator in" and "multiplexer out" tions. For similar performance in an 8-channel, 28-pin,

8-bit A/D converter, see the ADC0808, ADC0809 data sheet.

#### Features

- Resolution --- 8-bits ■ Total unadjusted error — ± 1/2 LSB and ± 1 LSB
- No missing codes
- Conversion time 100 µs

- Operates ratiometrically or with 5 V<sub>DC</sub> or analog span adjusted voltage reference
- 16-channel multiplexer with latched control logic
- Easy interface to all microprocessors, or operates "stand alone"
- Outputs meet T<sup>2</sup>L voltage level specifications
- 0V to 5V analog input voltage range with single 5V supply
- No zero or full-scale adjust required
- Standard hermetic or molded 40-pin DIP package ■ Temperature range -40°C to +85°C or -55°C to
- +125°C
- Low power consumption 15 mW Latched TRI-STATE® output
- for signal conditioning



#### Absolute Maximum Ratings

| Line Maximinut DSfil                                                                                                   | 195 (Notes 1 and 2)                |
|------------------------------------------------------------------------------------------------------------------------|------------------------------------|
| Supply Voltage( VCC) (Note 3)<br>Voltage at Any Pin<br>Except Control Inputs                                           | -0.3V to (VCC + 0.3V)              |
| Voltage al Control Inputs<br>(START, CE, CLOCK, ALE, EXPANSION CON<br>ADD A, ADD B, ADD C, ADD D)                      | -0.3V to 15V<br>TROL,              |
| Storage Temperature Nange<br>Package Dissipation al T <sub>A</sub> = 25 °C<br>Lead Temperature (Soldering, 10 aeconds) | 65°C to + 160°C<br>875 mW<br>300°C |

#### **Electrical Characteristics**

 $\textbf{Converter Specifications: } V_{CC} = 5 V_{DC} = V_{REF(+)} V_{REF(-)} = \text{GND}, V_{IN} = V_{COMPARATOR IN}, T_{MIN} \leq T_A \leq T_{MAX} \text{ and } V_{MIN} = V_{COMPARATOR IN}, T_{MIN} \leq T_A \leq T_{MAX} \text{ and } V_{MIN} = V_{MIN} = V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} + V_{MIN} +$ 

| F       | eremeter                                                                                                                                                                                                | meter Conditions Min                                                                                                                                                        |                 | T                                       | T                                                                                                                                                             | 1.                                                |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|
|         | ADC0818<br>Total Unadjusted Error<br>(Note 5)<br>ADC0817<br>Total Unadjusted Error<br>(Note 5)<br>Input Resistance<br>Analog input Voltage Range<br>Voltage, Top of Ladder<br>Voltage, Center of Ladder | 25°C<br>T <sub>MIN</sub> to T <sub>MAX</sub><br>0°C to 70°C<br>T <sub>MIN</sub> lo T <sub>MAX</sub><br>From Ref(+) to Ref(-)<br>(Note 4) V(+) or V(-)<br>Measured at Ref(+) | 1.0<br>GND-0.10 | <b>Typ</b><br>4.5<br>V <sub>CC</sub> /2 | $\begin{array}{c} \text{Max} \\ \pm \ 1/2 \\ \pm \ 3/4 \\ \pm \ 1 \\ \pm \ 1 \ 1/4 \\ V_{CC} \pm \ 0.10 \\ V_{CC} \pm \ 0.10 \\ V_{CC} \pm \ 0.1 \end{array}$ | Units<br>LSB<br>LSB<br>LSB<br>kΩ<br>Voc<br>V<br>V |
| VAEFI-1 | Voltage, Bottom of Ladder<br>Comparator Input Current                                                                                                                                                   | Measured at Ref( - )<br>f <sub>c</sub> = 640 kHz, (Nole 6)                                                                                                                  | -0.1            | 0<br>±0,5                               | 2                                                                                                                                                             | V<br>⊭A                                           |

#### **Electrical Characteristics**

Digital Levels and DC Specifications: ADC0816C J 4.5V  $\leq$  V<sub>CC</sub>  $\leq$  6.5V, -55°C  $\leq$  T<sub>A</sub> $\leq$  + 125°C unless otherwise noted. ADC0816CCJ, ADC0816CCN, ADC0817CCN 4.75V ≤ V<sub>CC</sub>≤5.25V, ~40°C≤T<sub>A</sub>≤ + 85°C unless otherwise note

|                                     | Parameter                                              | Conditions                                                                                              | Min                  | 7   | T          | - <u></u>      |  |
|-------------------------------------|--------------------------------------------------------|---------------------------------------------------------------------------------------------------------|----------------------|-----|------------|----------------|--|
| ANALOG N                            | IVLTIPLEXER                                            | ······································                                                                  |                      | Тур | Max        | Units          |  |
| A <sub>ON</sub>                     | Analog Multiplexer ON<br>Resistance                    | (Any Selected Channel)<br>$T_A = 25^{\circ}C, R_L = 10k$<br>$T_A = 85^{\circ}C$<br>$T_A = 125^{\circ}C$ |                      | 1.5 | 3          | kΩ<br>kΩ       |  |
| 78 <sup>04</sup>                    | 소 ON Resistance Between Any<br>2 Channels              |                                                                                                         |                      | 75  | 9          | kΩ<br>Ω        |  |
| IOFF(+) DFF Channel Leakage Current |                                                        | $V_{CC} = 5V, V_{IN} = 5V,$<br>$T_A = 25^{\circ}C$<br>Turn to Turn                                      | - 200<br>- 1.0       | 10  | 200<br>1.0 | nA<br>µA<br>aA |  |
| CONTROL I                           | PUTS                                                   |                                                                                                         |                      |     | L          | μA             |  |
|                                     | Logical "1" input Voltage<br>Logical "0" Input Voltage |                                                                                                         | V <sub>CC</sub> -1.5 |     | 1.5        | v<br>v         |  |
| lan(1)                              | Logical "1" Input Current<br>(The Control Inputs)      | V <sub>IN</sub> ≖ 15V                                                                                   |                      | Í   | 1.0        | v<br>مر        |  |
| .1 <sub>IN(0)</sub>                 | Logical "0" input Current<br>(The Control Inputs)      | 0 = <sub>או</sub> ۷                                                                                     | -1.0                 | Í   |            | A۾             |  |
| lcc                                 | Burnets Output                                         | CLK = 640 kHz                                                                                           | }                    | 0.3 | 3.0        | mA             |  |

#### Operating Ratings (Notes 1 and 2)

Temperature Range (Note 1) ABC0818CJ ADC0816CCJ, ADC0816CCN, ADC0817CCN Range of VCC (Note 1) Vollage at Any Pin Except Control Inputs Charge Control Inputs Voltage at Control Inputs (START, DE, CLOCK, ALE, EXPANSION CONTROL, ADD A, ADD B, ADD C, ADD D)

ADC0816, TMIN ≤ TA S TMAX - 55°C ≤ TAS + 125°C -40"C = TA = +85"C 4.5 VDC 108.0 VDC OV 10 VCC >DC0817 DV to 15V

#### Electrical Characteristics (Continued)

Digital Levels and DC Specifications: ADC0816C J 4.5V  $\leq$  V<sub>CC</sub>  $\leq$  5.5V,  $-55^{\circ}$ C  $\leq$  T<sub>A</sub>  $\leq$  + 125^{\circ}C unless otherwise noted. ADC0816CCJ, ADC0816CCN, ADC0817CCN 4.75V ≤ V<sub>CC</sub> ≤ 5.25V, - 40°C ≤ T<sub>A</sub> ≤ + 85°C unless otherwise noted.

|                     | Parameter                      | Conditions                               | Min     | Тур | Max  | Units    |
|---------------------|--------------------------------|------------------------------------------|---------|-----|------|----------|
| DATA OUTP           | UTS AND EOC (INTERRUPT)        |                                          |         |     |      | L        |
| V <sub>OUT(1)</sub> | Logical "1" Output Voltage     | I <sub>O</sub> = - 360 μA                | Vcc-0.4 |     |      | v        |
| V <sub>OUT(0)</sub> | Logical "0" Output Voltage     | l <sub>O</sub> = 1.6 mA                  |         |     | 0.45 | v        |
| V <sub>OUT(0)</sub> | Logical "0" Output Voltage EOC | t <sub>o</sub> = 1.2 mA                  |         |     | 0.45 | v        |
| lour                | TRI-STATE Output Current       | $V_{\rm O} = V_{\rm CC}$ $V_{\rm O} = 0$ | -3      |     | 3    | μA<br>μA |

#### **Electrical Characteristics**

ADC0816, ADC0817

Timing Specifications:  $V_{CC} = V_{REF(+)} = 5V$ ,  $V_{REF(-)} = GND$ ,  $t_i = t_i \approx 20$  ns and  $T_A = 25^{\circ}C$  unless otherwise noted.

| Symbol                            | Parameter                         | Conditions                                                       | Min | Тур | Max    | alinU            |
|-----------------------------------|-----------------------------------|------------------------------------------------------------------|-----|-----|--------|------------------|
| t <sub>ws</sub>                   | Minimum Start Pulse Width         | (Figure 5)                                                       |     | 100 | 200    | ns               |
| twale                             | Minimum ALE Pulse Width           | (Figure 5)                                                       |     | 100 | 200    | ns               |
| t <sub>s</sub>                    | Minimum Address Set-Up Time       | (Figure 5)                                                       | 1   | 25  | 50     | ns               |
| t <sub>H</sub>                    | Minimum Address Hold Time         | (Figure 5)                                                       |     | 25  | 50     | ns               |
| tp                                | Analog MUX Delay Time<br>From ALE | R <sub>S</sub> =0Ω (Figure 5)                                    |     | 1   | 2.5    | μS               |
| t <sub>H1</sub> , t <sub>H0</sub> | OE Control to Q Logic State       | C <sub>L</sub> = 50 pF, R <sub>L</sub> ⇒ 10k <i>(Figure 8)</i>   |     | 125 | 250    | ns               |
| t <sub>1н</sub> , t <sub>0н</sub> | OE Control to Hi-Z                | C <sub>L</sub> = 10 ρF, R <sub>L</sub> = 10k ( <i>Figure 8</i> ) |     | 125 | 250    | лs               |
| 1 <sub>c</sub>                    | Conversion Time                   | f <sub>c</sub> = 640 kHz, ( <i>Figure 5</i> ) (Note 7)           | 90  | 100 | 116    | μs               |
| f <sub>c</sub>                    | Clock Frequency                   |                                                                  | 10  | 640 | 1280   | kHz              |
| 1EOC                              | EOC Delay Time                    | (Figure 5)                                                       | 0   |     | 8+2 µs | Clock<br>Periods |
| CIN                               | Input Capacitance                 | Al Control Inputs                                                |     | 10  | 15     | p₽               |
| COUT                              | TRI-STATE Output<br>Capacitance   | At TRI-STATE Outputs, (Note 7)                                   |     | 10  | 15     | pF               |

Note 1: Absolute maximum ratings are those values beyond which the life of the device may be impaired

Note 2: All voltages are measured with respect to GND, unless otherwise specified.

Note 3: A zener diode exists, internally, from VCC to GND and has a typical breakdown voltage of 7 VDC-

Note 4: Two indoe wrise, internain, non rtg, to arrow and near any point or section or section or ong or r rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or rouge or roug of y voltage of 4.900  $V_{DC}$  over temperature variations, initial tolerance and fording.

Note 5: Total unadjusted error includes offset, full-scale, and linearly errors. See Figure 3. None of these A/Ds requires a zero or full-scale adjust. However, if an all zero code is desired for an analog input other than 0.0V, or if a narrow full-scale span exists (for example: 0.5V to 4.5V full-scale) the reference voltages can be adjusted to achieve this. See Figure 13.

Note 6: Comparator input current is a blas current into or out of the chopper stabilized comparator. The bias current varies directly with clock frequency and has little temperature dependence (Figure 6). See paragraph 4.0.

Note 7: The outputs of the data register are updated one clock cycle before the rising edge of EOC.







#### **Functional Description**

SELECTED

ANALOG CHANNEL

INC

IN1

IN2

IN3

INA

IN5

IN6

IN7

INS

iN9

IN10

IN11

IN12

IN13

IN14

IN15

All Channels OFF

Multiplexer: The device contains a 16-channel single-ended analog signal multiplexer. A particular input channel is selected by using the address decoder. Table i shows the input states for the address line and the expansion control line to select any channel. The address is latched into the decoder on the low-to-high transition of the address latch enable signal.



L L

н ιI н

н

н ł

нІс

54

L Ł

L L L

L

. L н н

L н L L

Ł н н

н

н

н н

н H н н

D C B A CONTROL

н

н

в

н

н

н

н

н

н

H

н

н

н

н

н

Additional single-ended analog signals can be multiplexed to the A/D converter by disabling all the multiplexer inputs using the expansion control. The additional external signals are connected to the comparator input and the device ground. Additional signal conditioning (i.e., prescaling, sample and hold, instrumentation amplification, etc.) may also be added between the analog input signal and the comparator input.

#### CONVERTER CHARACTERISTICS

#### The Converter

The heart of this single chip data acquisition system is its 8-bit analog-to-digital converter. The converter is designed to give fast, accurate, and repeatable conversions over a wide range of temperatures. The converter is partitioned into 3 major sections: the 255R ladder network, the successive approximation register, and the comparator. The converter's digital outputs are positive true

The 256R ladder network approach (Figure 1) was chosen over the conventional Rv2R ladder because of its inherent monotonicity, which guarantees no missing digital codes. Monotonicity is particularly important in closed loop feedback control systems. A non-monotonic relationship can cause oscillations that will be catastrophic for the system. Additionally, the 256R network does not cause load variations on the reference voltage.

The boltom resistor and the top resistor of the ladder network in Figure 1 are not the same value as the remainder of the network. The difference in these resistors causes the output characteristic to be symmetrical with the zero and full-scale points of the transfer curve. The first output transition occurs when the analog signal has reached + 1/2 LSB and succeeding output transitions occur every 1 LSB later up to full-scale.

# ADC0816, ADC0817

#### Functional Description (Continued)

ADC0817

ADC0816,

The successive approximation register (SAR) performs 8 Iterations to approximate the input voltage. For any SAR type converter, n-iterationa are required for an n-bit converter. Figure 2 shows a typical example of a 3-bit converter. In the ADC0816, ADC0817, the approximation technique is extended to 8 bits using the 256R network.

The A/D converter's successive approximation register (SAR) is reset on the positive edge of the start conversion (SC) pulse. The conversion is begun on the failing edge of the start conversion pulse. A conversion in process will be Interrupted by receipt of a new start conversion pulse. Continuous conversion may be accomplished by tying the end-of-conversion (EOC) output to the SC Input. If used in this mode, an external start conversion pulse should be applied after power up. End-of-conversion will go low between 0 and 8 clock pulses after the rising edge of start conversion.

The most important section of the A/D converter is the comparator. It is this section which is responsible for the ultimate accuracy of the entire converter. It is also the comparator drift which has the greatest influence on the repeatability of the device. A chopper-stabilized com-parator provides the most effective method of satisfying all the converter requirements.

The chopper-stabilized comparator converts the DC input signal Into an AC signal. This signal is then fed through a high gain AC amplifier and has the DC level restored. This technique limits the drift component of the amplifier since the drift is a DC component which is not passed by the AC amplifier. This makes the entire A/D converter extremely Insensitive to temperature, long term drift and input offset errors.

Figure 4 shows a typical error curve for the ADC0816 as measured using the procedures outfined in AN-179.



# 1113 - 2 1144 - 2 1144 - 2 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 - 4 1145 -START N B IN REF(+) = 6NC





#### TRI-STATE® Test Circuits and Timing Diagrams



### Applications Information

1.0 Retionetric Conversion

The ADC0816, ADC0817 is designed as a complete Data Acquisition System (DAS) for ratiometric conversion systems. In ratiometric systems, the physical variable being measured is expressed as a percentage of full-acate which is not necessarily related to an absolute standard. The voltage input to the ADC0816 is expressed by the equation



 $V_{IN} = Input voltage into the ADC0816$   $V_{fe} \approx Fuil-scale voltage$   $V_Z = Zero voltage$   $D_X = Data point being measured$   $D_{MAX} \approx Maximum data limit$  $D_{MIN} = Minimum data limit$ 

A good example of a ratiometric transducer is a potentiometer used as a position sensor. The position of the wiper is directly proportional to the output voltage which is a ratio of the full-scale voltage across it. Since the data is represented as a proportion of full-scale, reference requirements are greatly reduced, eliminating a large source of error and cost for many applications. A major advantage of the ADC0816, ADC0817 is that the input voltage range is equal to the supply range so the transducers can be connected directly across the supply and their outputs connected directly into the multiplexer inputs, (Figure 9).



100

Ratiometric transducers such as potentiometers, strain gauges, thermistor bridges, pressure transducers, etc., are suitable for measuring proportional relationships; however, many types of measurements must be referred to an absolute standard such as voltage or current. This means a system reference must be used which relates the full-scale voltage to the full-scale range is divided into 256 standard steps. The smallest standard step is 1 LSB which is then 20 mV.

#### 2.0 Resistor Ladder Limitations

The voltages from the resistor ladder are compared to the selected input 8 times in a conversion. These voltages are coupled to the comparator via an analog switch tree which is referenced to the supply. The voltages at the top, center and bottom of the ladder must be controlled to maintain proper operation.

The top of the ladder, Ref(+), should not be more positive than the supply, and the bottom of the ladder, Ref(-), should not be more negative than ground. The center of the ladder voltage must also be near the center of the supply because the analog switch tree changes from N-channel switches to P-channel switches. These limitations are automatically satisfied in ratiometric systems and can be easily met in ground referenced systems.

Figure 10 shows a ground referenced system with a separate supply and reference. In this system, the supply must be trimmed to match the reference voltage. For instance, if a 5.12V reference is used, the supply should be adjusted to the same voltage within 0.1V.

# ADC0816, ADC0817

#### Applications Information (Continued)

The ADC0816 needs less than a milliamp of supply current so developing the supply from the reference is readily accomplished. In Figure 11 a ground referenced system is shown which generates the supply from the reference. The buffer shown can be an op amp of sufficient drive to supply the milliamp of supply current and the desired bus drive, or if a capacitive bus is driven by the outputs a large capacitor will supply the transient supply current as seen in Figure 12. The LM301 is overcompensated to insure stability when loaded by the 10  $\mu\text{F}$  output capacitor.

The top and bottom ladder voltages cannot exceed  $V_{CC}$ and ground, respectively, but they can be symmetrically less than V<sub>CC</sub> and greater than ground. The center of the ladder voltage should always be near the center of the supply. The sensitivity of the converter can be increased, (i.e., size of the LSB steps decreased) by using a symmetrical reference system. In Figure 13, a 2.5V reference is symmetrically centered about  $V_{CC}/2$  since the same current flows in identical resistors. This system with a 2.5V reference allows the LSB to be half the size of the LSB in a 5V reference system.



#### FIGURE 10. Ground Referenced **Conversion System Using Trimmed Supply**











# National Semiconductor

#### Digital-to-Analog Converters

DAC0800

100 as

±1 LSB

±0.1%

#### DAC0800 8-Bit Digital-to-Analog Converter

#### **General Description**

The DAC08 is a monolithic 8-bit high-speed currentoutput digital-to-analog converter (DAC) featuring typical settling times of 100 ns. When used as a multiplying DAC, monotonic performance over a 40 to 1 reference current range is possible. The DAC08 also features high compliance complementary current outputs to allow differential output voltages of 20 Vp-p with simple resistor loads as shown in Figure 1. The referenceto-full-scale current matching of better than ±1 LSB eliminates the need for full scale trims in most applications while the nonlinearities of better than ±0.1% over temperature minimizes system error accumulations,

The noise immune inputs of the DAC08 will accept TTL levels with the logic threshold pin, VLC, pin 1 grounded. Simple adjustments of the VLC potential allow direct interface to all logic families. The performance and characteristics of the device are essentially unchanged over the full  $\pm 4.5V$  to  $\pm 18V$  power supply range; power dissipation is only 33 mW with  $\pm 5V$ supplies and is independent of the logic input states.

The DAC0800L, DAC0802L, DAC0809LC, DAC0801LC and DAC0802LC are a direct replacement for the DAC08, DAC08A, DAC08C, DAC08E and DAC08H, respectively.

#### Features

- Fast settling output current
- Full scale error.
- Nonlinearity over temperature
- Full scale current drift ±10 ppm/°C
- High output compliance -10V to +18V
- Complementary current outputs ■ Interface directly with TTL, CMOS, PMOS and
- others
- 2 quadrant wide range multiplying capability
- Wide power supply range ±4.5V to ±18V 33 m₩ at ±5V
- Low power consumption Low cost



#### **Ordering Information**

- - -

| NON LINEARITY | TEMPERATURE                                  | ORDER NUMBER\$* |           |            |           |                  |           |  |  |  |  |
|---------------|----------------------------------------------|-----------------|-----------|------------|-----------|------------------|-----------|--|--|--|--|
|               | L. RANGE                                     | D PACKA         | GE (D16C) | \$ PACKA   | GE (J16A) | N PACKAGE (N16A) |           |  |  |  |  |
| ±0.1% FS      | $-55^{\circ}C \leq T_{A} \leq +125^{\circ}C$ | DAC0802LD       | LMDAC08AD |            |           |                  |           |  |  |  |  |
| ±0.1% FS      | $0^{\circ}C \leq T_{A} \leq \pm 70^{\circ}C$ |                 |           | DAG0802LCJ | LMDAC08HJ | DAC0802LCN       | LMDAC08HN |  |  |  |  |
| ±0.19% FS     | -55°C ≤ TA ≤ + 125°C                         | DACOBOOLD       | LMDAC08D  |            |           |                  |           |  |  |  |  |
| ±0.19% FS     | $0^{\circ}C \leq T_{A} \leq +70^{\circ}C$    |                 |           | DAC0800LCJ | LMDACOSEJ | DAC0800LCN       | LMDACOBEN |  |  |  |  |
| 10.39% FS     | $0^{\circ}C \leq T_{A} \leq +70^{\circ}C$    |                 |           | DAC0801LCJ | LMDAC08CJ | DAC0801LCN       | LMDAC08CN |  |  |  |  |

**DAC0800** Absolute Maximum Ratings **Operating Conditions** Supply Voltage Power Dissipation (Note 1) 18V or 36V 500 mW V<sup>-+</sup> to V<sup>+</sup> V<sup>-−</sup> to V<sup>+</sup> Reference Input Differential Voltage (V14 to V15) Reference input Common-Mode Range (V14, V15) Reference Input Current Lugic Inputs Lugic Inputs Analog Current Outputs Storage Temperature Lead Temperature (Soldering, 10 seconds) 5 mA V<sup>--</sup> to V<sup>--</sup> plus 36V Figure 24 -65°C to +150°C 300° C Electrical Characteristics (V<sub>S</sub> = ±15V, I<sub>REF</sub> = 2 mA, T<sub>MIN</sub>  $\leq$  T<sub>A</sub>  $\leq$  T<sub>MAX</sub> unless otherwise specified. Output characteristics refer to both (OUT and IOUT.)

| PARAMETER                       | CONDITIONS                                                               | CONDITIONS |        | DAC0802L/<br>DAC0802LC |                  |                 | DAC0800L/<br>DAC0800LC |                     |                 |                   | DAC0801LC         |                    |                |             |
|---------------------------------|--------------------------------------------------------------------------|------------|--------|------------------------|------------------|-----------------|------------------------|---------------------|-----------------|-------------------|-------------------|--------------------|----------------|-------------|
| Resolution                      |                                                                          | F          | MIN    | TY                     |                  | ix †            | MIN                    | TYP                 | LC<br>MAX       | <u> </u>          |                   | _                  |                | UNIT        |
| Monotonicity                    | l l                                                                      | 1          | 8 T    | 8                      | 8                | -+-             | 8                      | B                   | 8               |                   |                   |                    | MAX            |             |
|                                 |                                                                          |            | 8      | 8                      | 8                | 1               | 8                      | 8                   | 1               | [                 | 1                 | 1                  | 8              | ₿r          |
| Nonlinearity                    |                                                                          | - 1        | - 1    |                        | 20,1             |                 | °                      | ¢                   | 8               | 6                 | 18                |                    | 8              | 8i          |
| ts Sentling Time                | To ± 1/2 LSB, Atl Bits Switched                                          | . !        | !      |                        |                  | 1               |                        |                     | 10,19           | 1                 |                   | 1 1                | 0.39           | %F          |
|                                 | "ON" or "OFF", 1A - 25°C                                                 | ·          | 1      | 100                    | 135              |                 |                        |                     |                 |                   | 1.1               | 30 I               | 150            |             |
| [                               | DACOBODI                                                                 |            | 1      |                        |                  |                 |                        |                     |                 | 1                 |                   | 1                  |                | п           |
|                                 | DACOBOGLC                                                                |            |        |                        | 1                |                 | 1                      | 100                 | 135             |                   | 1                 |                    |                |             |
| PLM. TPHL Propagation Delay     | TA = 25°C                                                                |            |        |                        |                  |                 |                        | 100                 | 150             | 1                 |                   | 1                  | i              | P           |
| Each Bit                        |                                                                          |            |        |                        |                  | 1               | - [                    |                     |                 | 1                 |                   | 1                  |                | n           |
| All Bits Switched               |                                                                          | 1          |        | 35                     | 60               |                 | - 1                    | 35                  | 60              |                   | 35                |                    |                |             |
| TCIPS Full Scale Tampto         | [                                                                        |            |        | 35                     | 60               |                 |                        | 35                  | 60              | ]                 | 35                |                    |                | <b>n</b> 1  |
| VOC Output Voltage Com          |                                                                          | 1          | 1      | 10                     | ±50              |                 | 1.                     | 10                  | ±50             | 1                 | 110               | ·                  |                | <b>n</b> \$ |
| - the stronge com               |                                                                          | -10        |        |                        | 18               | - I - 1         | ۰İ                     |                     |                 |                   |                   | ±8                 | 0 [ppn         | ⊓⁄°Ç        |
| FS4 Full Scale Current          | < 1/2 LSB, ROUT > 20 MS2 THE                                             | >          | i      |                        |                  | 1               |                        |                     | 18              | [ ~1              | 0                 | - ( "              | 9              | v           |
| 1 34 OF Scale Corrent           | VREF = 10 000V, R14 = 5.000 k                                            | രില        | 984    | 1.992                  | 2.000            |                 | 94                     |                     |                 |                   |                   |                    | 1              |             |
| FSS Full Scale Symmetry         | 815 - 5.000 kS2, TA = 25°C                                               |            |        |                        | 4.000            | 1 "             | 94                     | 99                  | 2.04            | 1.8               | 1,9               | 9 2,               | 04             | πA          |
|                                 | 1F\$4 - 1F\$2                                                            |            | Ι.     | 05                     | :4.0             |                 |                        | 1                   |                 |                   |                   |                    | ſ              |             |
| ZS Zero Scale Current           |                                                                          |            |        |                        |                  | 1               | 11                     |                     | 8.0             |                   | 22                | 1 110              | í              | μA          |
| IFSR Output Current Range       | V ~5V                                                                    |            | 10     | u I                    | 1.0              | 1               | 1                      | 12                  | 2.0             |                   | 0.2               | 1 4.0              | 1              | μА          |
| 2                               | V = -BV to 18V                                                           | 10         | 2      | 0 1                    | 2.1              | 0               | 2                      | 0                   | 21              | 0                 | 2.0               |                    |                |             |
| Logic Input Levels              |                                                                          | 0          | 2.     | .0                     | 4.2              | 0               | 1 2                    | 0                   | 4.2             | õ                 | 2.0               | 2.1                |                | n.A.        |
| VIL Logie "0"                   | 14.5                                                                     |            | 1      | 1                      |                  |                 |                        |                     |                 | č                 | 2.0               | 4.2                | 1 '            | nĄ          |
| VIN Logic "T"                   | VLC - OV                                                                 |            | 1      | 1                      | 8 0              | 1               |                        |                     | 0.8             |                   |                   |                    | i              |             |
| Logic Input Current             |                                                                          | 20         |        | 1                      |                  | 2.0             |                        |                     | <sup>~~</sup> ( | 20                | [                 | 0.B                | 1              | ۷           |
| IL Logic "0"                    | V <sub>LC</sub> = 0V                                                     | 1          |        |                        |                  |                 | 1                      |                     |                 | 10                |                   |                    |                | ٧           |
| IH Logic "1"                    | $-10V \leq VIN \leq +0.8V$                                               | 1          | 1-2.0  | ء   <sub>-</sub>       | 10               |                 | 1-2                    | • [_                |                 |                   |                   | 1                  |                |             |
|                                 | $3N \leq A^{1N} \leq +18N$                                               |            | 0.0    |                        | 10               |                 |                        |                     |                 |                   | -2.0              | [ -10              | 1 1            | A           |
|                                 | V > -16V                                                                 | 1-10       | 1      | 1                      | 18               | -10             | 1.                     |                     |                 | (                 | 0.002             | 10                 | µ              | A           |
| VTHA Logic Threshold Range      | Vs • 115V                                                                | -10        |        |                        |                  |                 | i i                    | 1                   | 8  -            | -10               |                   | 18                 |                | v           |
| 16 Reference Bies Current       |                                                                          | 1.0        | 1      |                        | 1                | -10             | [                      |                     | 3.5 -           | 10                |                   | 13.5               | 1              | v           |
| di/dt Reference input Slew 8a   | ta (Figure 24)                                                           | 1          | -1.0   | _  ∹                   | 3.0              |                 | 1.1.3                  | -3                  | 0               |                   | -1.0              | -30                |                | ·           |
| SSIFS+ Power Supply Sensitivity |                                                                          | 1          | 8.0    |                        |                  |                 | 80                     |                     |                 |                   |                   | 1 30               | <sup>س</sup> [ | · 1         |
| SSIFS.                          |                                                                          | 1          | 0.00   | 201 0                  | 101              |                 | 0.0                    |                     |                 |                   | 9.0               | 1                  | mA/µ           | s ļ         |
|                                 | -4.5V ≤ V * < 18V                                                        |            | 0.00   | - I '                  | 01               |                 | 00                     |                     | 01              | 1                 | 0.0001            |                    | \$/3           |             |
| Power Supply Correct            | IREF = 1 mA                                                              | 1          | ļ .    | 1                      |                  |                 | 0.00                   | ~~~ U               | "               | 1                 | 0.0001            | 0.01               | <b>%/X</b>     | · 1         |
| +                               | Vs * 15V, IREF = 1 mA                                                    |            | 1      |                        | 1                |                 |                        |                     |                 | 1                 |                   |                    | í              |             |
| -                               | 1                                                                        | 1          | 2.3    | 1 3                    | 8                | 1               | 2.3                    |                     |                 |                   |                   |                    | 1              | 1           |
|                                 | 1                                                                        |            | 43     | - 5                    | 8                |                 | -4.3                   | 3.6                 | · 1             |                   | 2.3               | 3.8                | mA             | 1           |
| •                               | VS = 5V, - 15V, TREF = 2 mA                                              | 1          |        |                        |                  |                 |                        | 1-2.6               | ·               | - 1°              | 4.3               | -5.8               | mA             |             |
|                                 |                                                                          | [ ]        | 2.4    | 3.                     | •                | - 1             |                        | 1                   | 1               |                   | (                 |                    |                |             |
|                                 |                                                                          |            | -6.4   | 1.7.1                  |                  |                 | 24<br>-8.4             | 3.8                 |                 |                   | 24                | 3.8                | mΑ             |             |
|                                 | VS = 115V, IREF = 2 mA                                                   |            |        |                        |                  |                 | 0.4                    | -7.8                |                 | -6                | 4                 | ~7.8               | mΑ             |             |
|                                 | 1 1                                                                      |            | 2.5    | 38                     |                  | 1               |                        |                     | 1               |                   | - 1               |                    |                | 1           |
| Power Discretion                | 1                                                                        |            | -6.5   | 7.8                    |                  |                 | 25<br>6.5              | 3.8                 |                 | -                 | .5                | 3.8                | mА             | [           |
| Power Dissrpation               | *5V.1REF=1mA                                                             |            | 33     | 1                      |                  |                 |                        | -7.8                |                 | [ <del>-</del> 6. | .6                | -7.8               | mA             |             |
|                                 | 5V 15V. TREF * 2 mA                                                      |            | 108    | 48                     |                  |                 | 33                     | 48                  |                 | 3:                | 3 <b> </b> .      | 48                 | m₩             |             |
| 44 1. 74.                       | 1 115V Inco a dava                                                       |            |        |                        |                  |                 | 108                    | 136                 |                 | 11                | DB                | 136                | m₩             |             |
| the dual in the first on D      | mperature of the DAC0800, DACON                                          |            | 14.000 | 1. <u>//</u>           |                  |                 | 135                    | 174                 | 1               | _ [ 13            | 15                | 174                | mΨ             | 1           |
| ine N package.                  | mperature of the DAC0800, DAC080<br>nust be derated based on a thermal r | esistanc   | e of 1 | 00°C,                  | 100°C<br>∿¥, jun | . For<br>Iction | əper<br>toar           | ating at<br>Nbient, | elevet<br>175°C | editer<br>:/₩fp   | nperat<br>r the r | ures, de<br>noldad | vices<br>dual- |             |

| Temperature (TA)     | MtN | ΜΑχ  | UNITS      |
|----------------------|-----|------|------------|
| DAC0802LA, LMDAC08A  | -55 | +125 | ာံတံ့ ဂံဂံ |
| DAC0800L, LMDAC08    | -55 | +125 |            |
| DAC0800LC, LMDAC08E, | 0   | +70  |            |
| DAC0801LC, LMDAC08E, | 0   | +70  |            |
| DAC0802LC, LMDAC08H  | 0   | +70  |            |











