| AD-      | A16 | 4 203<br>51f1E0 | THE<br>MOT<br>NRI<br>DEC | SIMUL<br>OROLA<br>GHT-PA<br>84 AF | ATION<br>MC690<br>TTERS<br>IT/GC | AND A<br>DO HIC<br>DN AFB<br>5/ENG/ | NALYSI<br>ROP<br>OH SC<br>84D-2- | S OF (<br>U) AI<br>Hool (<br>-Vol-1 | A RTL<br>R Forc<br>DF Eng | NODEL<br>E INSI<br>I ( | OF TH<br>OF TH<br>A BA<br>F/G | E<br>ECH<br>KLEY<br>9/2 | 1/<br>NL | /2 |   |
|----------|-----|-----------------|--------------------------|-----------------------------------|----------------------------------|-------------------------------------|----------------------------------|-------------------------------------|---------------------------|------------------------|-------------------------------|-------------------------|----------|----|---|
|          |     |                 | ,                        | 5.3                               |                                  |                                     |                                  |                                     |                           |                        |                               |                         |          |    |   |
|          |     |                 |                          |                                   |                                  |                                     |                                  |                                     |                           |                        |                               |                         |          |    |   |
|          |     |                 |                          |                                   |                                  |                                     |                                  |                                     |                           |                        |                               |                         |          |    |   |
|          |     |                 |                          |                                   |                                  |                                     |                                  |                                     |                           |                        |                               |                         |          |    |   |
|          |     |                 |                          |                                   |                                  |                                     |                                  |                                     |                           |                        |                               |                         |          |    |   |
|          |     |                 |                          |                                   |                                  |                                     |                                  |                                     |                           |                        |                               |                         |          |    |   |
|          |     |                 |                          |                                   |                                  |                                     |                                  |                                     |                           |                        |                               |                         |          |    |   |
| <u> </u> |     | _               |                          |                                   |                                  |                                     |                                  |                                     |                           |                        |                               |                         |          |    | 1 |



MICROCOPY RESOLUTION TEST CHART



AFIT/GCS/ENG/84D-2-Vol-L JTIC ELECTE FEB 1 3 1986 D THE SIMULATION AND ANALYSIS OF A RTL MODEL OF THE MOTOROLA MC68000 MICROPROCESSOR WITH N.MPC. Volume 1 THESIS () of 3) See also Vil. 31 A. AISI 962 Charles A. Baxley Jr. Captain, USAF AFIT/GCS/ENG/84D-2-Vol 1 Approved for public release; distribution unlimited

AFIT/GCS/ENG/84D-2 - Vot-1

()

THE SIMULATION AND ANALYSIS OF A RTL MODEL OF THE MOTOROLA MC68000 MICROPROCESSOR WITH N.MPC

### THESIS

Presented to the Faculty of the School of Engineering of the Air Force Institute of Technology

Air University

In Partial Fulfillment of the Requirements for the Degree of Master of Science in Electrical Engineering

| Acce                           | sion For                           | 1    |
|--------------------------------|------------------------------------|------|
| NTIS<br>DTIC<br>Uran<br>Justif | CRA&I<br>TAB<br>Nounced<br>Ication |      |
| By<br>Dist.it                  | Dution /                           |      |
| P                              | vailability C                      | odes |
| Dist                           | Avail and<br>Special               | or   |
| A-1                            |                                    |      |

Charles A. Baxley Jr., B.S. Captain, USAF

December 1984

Approved for public release; distribution unlimited

#### Preface

With the increasing complexity of today's microprocessors, gate level analysis and testing is no are not always available. In an earlier thesis, Captain James Hamby and Lt Galen Guillory presented a method for analyzing and modeling these new microprocessors at the functional level without using manufacturing information. In this follow-on thesis, I document the simulation of those microprocessor models developed by Hamby and Guillory and present an evaluation of their modeling approach based on \_1<caption> opportunity to apply much of the course material taken while at AFIT, it introduced me to new areas in the field of computer architecture, and it enabled me to examine a valid problem facing today's Air Force.

I would like to extend my sincere appreciation to my Thesis Advisor, Major Fred Zapka, who provided me with first-rate guidance whenever the direction of my work became clouded with technical and administrative problems. Without his expert instruction and consistent enthusiasm, I would certainly have fallen short of the major objectives of this work and the quality of this report would have diminished substantially. I would also like to thank my Thesis Reader, Lt Col Hal Carter, for his support; particularly for

ii

acquiring the simulation package that made this work possible and assisting in its installation. I also thank Major Ken Melendez of the Foreign Technology Division (FTD) for his support as the sponsor of this project and hope that my work has been beneficial to FTD. Finally, I would like to thank my wife, Lois, and my son, Allen, for their endless patience, understanding, and support during those many hours we were separated by this work.

0

## <u>Contents</u>

1

## (Volume I)

, L

|      | pag                                                                                                                                                   | ę                                    |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|
| I.   | IntroductionI-                                                                                                                                        | 1                                    |
|      | Background                                                                                                                                            | 1445568                              |
| II.  | RequirementsII-                                                                                                                                       | 1                                    |
|      | Introduction II-<br>N.mPc Installation II-<br>Model Transformation II-<br>Simulation Strategy II-<br>Simulation Analysis II-<br>Detailed Time Log II- | 1<br>1<br>2<br>3<br>4<br>4           |
| III. | Intro to the Motorola MC68000 MicroprocessorIII-                                                                                                      | 1                                    |
|      | Introduction                                                                                                                                          | 1<br>1<br>2<br>5<br>8<br>1<br>3<br>6 |
| IV.  | Introduction to N.mPcIV-                                                                                                                              | 1                                    |
|      | Introduction                                                                                                                                          | 15837014                             |
| v.   | CDL-to-ISP' Model TransformationV-                                                                                                                    | 1                                    |
|      | IntroductionV-                                                                                                                                        | 1                                    |

| CDL/ISP<br>Effects o<br>Registe<br>Subregi<br>Buses .<br>Decoder<br>Clock .<br>Clock &<br>Switch<br>Model Cha<br>Memory 2<br>EXABUF<br>ABUS Ut<br>Memory 2<br>High Im<br>Power-O | ' Compa<br>f Langu<br>rs<br>sters .<br>Clock-(<br><br>Response<br>Size<br>ilizati<br>Declara<br>pedance<br>n Sequen | rison<br>age Diff<br>Cycle Co<br>Cycle Co<br>es<br>tion<br>Represe<br>nce | erences<br>Junter Rep<br>Intation | V-<br>V-<br>V-<br>V-<br>V-<br>V-<br>Presentation<br>V-<br>V-<br>V-<br>V-<br>V-<br>V-<br>V-<br>V-<br>V-<br>V-<br>V-<br>V-<br>V- | -2<br>12<br>13<br>13<br>15<br>21<br>21<br>24<br>25<br>26<br>25<br>26 |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|
| Drogram                                                                                                                                                                          | I ogđer                                                                                                             |                                                                           | mponenco                          | ······································                                                                                         | 20                                                                   |
| MC68000                                                                                                                                                                          | Doader                                                                                                              |                                                                           | • • • • • • • • •                 | ······································                                                                                         | 27                                                                   |
| MC00000                                                                                                                                                                          | Assemb.                                                                                                             | Lei                                                                       |                                   | · · · · · · · · · · · · · · · · · · ·                                                                                          | 21                                                                   |
| Cimulation                                                                                                                                                                       | 7 m n 7 m n i .                                                                                                     | _                                                                         |                                   |                                                                                                                                | ٦                                                                    |
| Simulation                                                                                                                                                                       | Analysis                                                                                                            | 5                                                                         |                                   | • • • • • • • • • • • • • • • • • • •                                                                                          | - I                                                                  |
| Introduct                                                                                                                                                                        | ion                                                                                                                 |                                                                           | • • • • • • • •                   | -<br>VI                                                                                                                        | -1                                                                   |
| Analysis I                                                                                                                                                                       | Results                                                                                                             |                                                                           | • • • • • • • •                   | • • • • • • • • • • • • • • • • • • •                                                                                          | -2                                                                   |
| High Impe                                                                                                                                                                        | dance Si                                                                                                            | cate                                                                      | • • • • • • • •                   | •••••VI                                                                                                                        | -3                                                                   |
| Data Bu                                                                                                                                                                          | s <b></b>                                                                                                           |                                                                           |                                   | VI                                                                                                                             | -4                                                                   |
| Address                                                                                                                                                                          | Bus                                                                                                                 |                                                                           |                                   | VI·                                                                                                                            | - 8                                                                  |
| Individua                                                                                                                                                                        | l Instru                                                                                                            | uction S                                                                  | imulation                         | n ResultsVI-                                                                                                                   | 10                                                                   |
| MOVE.W D1                                                                                                                                                                        | ,D2                                                                                                                 |                                                                           |                                   | vi-                                                                                                                            | 12                                                                   |
| MOVE W D1                                                                                                                                                                        | (Al) .                                                                                                              |                                                                           |                                   |                                                                                                                                | 13                                                                   |
| MOVE L DI                                                                                                                                                                        | Al                                                                                                                  |                                                                           |                                   |                                                                                                                                | 15                                                                   |
| MOVE W DI                                                                                                                                                                        | .(Al)+                                                                                                              |                                                                           |                                   |                                                                                                                                | 16                                                                   |
| MOVE W DI                                                                                                                                                                        | .04(21)                                                                                                             |                                                                           |                                   | VI-                                                                                                                            | īğ                                                                   |
| MOVE W DI                                                                                                                                                                        | ו נמ <i>ו</i> אח<br>ו נמו אח                                                                                        | ••••••<br>דר                                                              | •••••                             | VT~-                                                                                                                           | 21                                                                   |
| MOVE W DI                                                                                                                                                                        | \$2004                                                                                                              |                                                                           |                                   | · · · · · · · · · · · · · · · · · · ·                                                                                          | 21<br>22                                                             |
| MOVE W DI                                                                                                                                                                        | 172004 .<br>D2                                                                                                      |                                                                           |                                   |                                                                                                                                | 23                                                                   |
| MOVE W AL                                                                                                                                                                        |                                                                                                                     |                                                                           | • • • • • • • • •                 | , V 1 <sup></sup> .                                                                                                            | 25                                                                   |
| MOVE, W (A.                                                                                                                                                                      | 1), D2 • ·                                                                                                          | • • • • • • • • •                                                         | • • • • • • • • •                 | • • • • • • • • • • • • • • • • • • •                                                                                          | 20                                                                   |
| MOVE W (A                                                                                                                                                                        | 1)+,D6                                                                                                              | • • • • • • • •                                                           | • • • • • • • • •                 | ••••••••••••••••••••••••••••••••••••••                                                                                         | 27                                                                   |
| MOVE.W - (A                                                                                                                                                                      | AI),D4                                                                                                              | • • • • • • • •                                                           | • • • • • • • •                   | •••••VI-:                                                                                                                      | 28                                                                   |
| MOVE.W 04                                                                                                                                                                        | (A1),D1                                                                                                             |                                                                           | • • • • • • • • •                 | ,VI-:                                                                                                                          | 30                                                                   |
| MOVE.W 04                                                                                                                                                                        | (Al,D7)                                                                                                             | ,D2                                                                       |                                   | VI-3                                                                                                                           | 32                                                                   |
| MOVE.W \$20                                                                                                                                                                      | 004,D5 .                                                                                                            | • • • • • • • •                                                           |                                   |                                                                                                                                | 34                                                                   |
| MOVE.W \$20                                                                                                                                                                      | 004,\$200                                                                                                           | 80                                                                        |                                   | VI-:                                                                                                                           | 35                                                                   |
| MOVE.W #\$                                                                                                                                                                       | 5555,Dl                                                                                                             |                                                                           |                                   | vi-:                                                                                                                           | 38                                                                   |
| JMP (A0)                                                                                                                                                                         | •••••                                                                                                               |                                                                           |                                   | vi-:                                                                                                                           | 39                                                                   |
| ADD.W D3.I                                                                                                                                                                       |                                                                                                                     |                                                                           |                                   | VI-                                                                                                                            | 40                                                                   |
| BEO START                                                                                                                                                                        |                                                                                                                     |                                                                           |                                   |                                                                                                                                | 41                                                                   |
| BTST D1.()                                                                                                                                                                       | A1)                                                                                                                 |                                                                           |                                   | \$7T-                                                                                                                          | 45                                                                   |
| Illegal Tr                                                                                                                                                                       | nstructi                                                                                                            | on Exce                                                                   | ntion                             | VT-                                                                                                                            | 46                                                                   |
| Address Fi                                                                                                                                                                       | rror Ev                                                                                                             | rention                                                                   | E                                 |                                                                                                                                | 50                                                                   |
| HAALCOD DI                                                                                                                                                                       |                                                                                                                     | CPCT011                                                                   | • • • • • • • • •                 | · · · · · · · · · · · · · · · · · · ·                                                                                          | 50                                                                   |
| Conclusions                                                                                                                                                                      | and Rec                                                                                                             | commenda                                                                  | tions                             |                                                                                                                                | -1                                                                   |

VI.

VII.

Ì

ľ

)

ĥ

۲

v

|          | Introduct<br>Conclusio<br>Recommend | ion .<br>ons<br>lation |       | ••••    | ••••      | • • • • • • | • • • • | • • • • | •••• | VI<br>VI     | I-1<br>I-1<br>I-5 |
|----------|-------------------------------------|------------------------|-------|---------|-----------|-------------|---------|---------|------|--------------|-------------------|
| VIII. A  | nalysis o                           | Time                   | Spent | on      | Proje     | ect.        | • • • • | • • • • |      | .VII         | I <b>-</b> 1      |
|          | Introduct<br>Summary                | ion .<br>of Tim        | e     | ••••    | ••••      |             | ••••    | ••••    | •••• | .VII<br>.VII | :I-1<br>[I-1      |
| Bibliog: | raphy                               |                        |       | • • • • | • • • • • |             | • • • • | • • • • |      | BI           | [B-1              |

## (Volume II)

| Appendix A: | Local N.mPc SupplementA-1              |
|-------------|----------------------------------------|
| Appendix B: | CDL/ISP' Declaration SectionsB-1       |
| Appendix C: | ISP' Models of MC68000 InstructionsC-1 |
| Appendix D: | MC68000 Metamicro DescriptionD-1       |
| Appendix E: | MC68000 Linking/Loader DescriptionE-1  |
| Appendix F: | Test Routines (Metamicro)F-1           |
| Appendix G: | Simulation Control FilesG-1            |
|             |                                        |

í

•

## (Volume III)

| Appendix H | : Simulation OutputH-1                   |
|------------|------------------------------------------|
| Appendix I | : MC68000 CDL ModelsI-1                  |
| Appendix J | : Logic Analyzer DataJ-1                 |
| Appendix K | : ISP' Model of the RISC 1               |
| Appendix L | : Metamicro Description of the RISC 1L-1 |
| Vita       | VITA-1                                   |

# List of Figures

| Figure | Fag                                |
|--------|------------------------------------|
| III-1  | MC68000 Pin-Out DiagramIII-        |
| III-2  | Input and Output SignalsIII-       |
| III-3  | Register Org .izationIII-          |
| III-4  | Instruction CacheIII-              |
| III-5  | MC68000 ArchitectureIII-1          |
| III-6  | Data Organization In MemoryIII-1   |
| III-7  | Memory Word OrganizationIII-1      |
| III-8  | Addressing ModesIII-1              |
| III-9  | Instruction FormatIII-1            |
| III-10 | MC68000 Instruction SetIII-1       |
| IV-1   | N.mPc Block DiagramIV-             |
| IV-2   | Example Metamicro DescriptionIV-   |
| IV-3   | Linking/Loader Command ProgramIV-1 |
| IV-4   | Motorola MC68000 Topology FileIV-2 |
| VI-1   | Logic Analyzer Sampling PointsVI-  |
| VI-2   | Data Bus High Impedance TimingVI-  |
| • VI-3 | High Impedance on Address BusVI-   |
| VI-4   | Memory Access TypeVI-5             |

vii

#### Abstract

In a prior thesis project, a functional level model of portions of the Motorola MC68000 microprocessor was developed using signal analysis supported by limited technical data. Representative parts of the instruction set and exception processing structure were modeled with the Computer Design Language (CDL). In this follow-on effort, those CDL models are transformed into equivalent models using ISP', an enhanced version of the Instruction Set Processor (ISP) hardware design language. This language transformation enabled the models to be simulated using N.mPc, a VAX 11/780-hosted software package developed specifically to support the design of digital systems. To evaluate the correctness of the models, the simulation results are analyzed against signal data gathered with the aid of a logic analyzer during the actual operation of the MC68000 when processing the modeled instructions. The accuracy and completeness of the models suggest that this functional approach to microprocessor modeling is a valid one.

viii

## THE SIMULATION AND ANALYSIS OF A RTL MODEL OF THE MOTOROLA MC68000 WITH N.MPC

#### I. Introduction

#### Background

The number of off-the-shelf commercial microprocessors used in Air Force weapons systems is increasing at a dramatic rate. In contrast to specially-developed microprocessors designed for specific applications, off-the-shelf devices are readily available, less costly, and usually shorten system development time. However, they have one significant disadvantage - detailed technical data important to systems development is often unavailable. Technical data of interest include the schematic and logic diagrams, microcode descriptions, and production masks that are normally provided with specially-developed devices.

Because functional models of microprocessors are invaluable to their successful integration into modern weapons sytems, the Air Force has a strong interest in uncovering a method to develop functional microprocessor models without the benefit of the detailed technical data the situation common to off-the-shelf device utilization.

In an effort to assist the Air Force in obtaining a solution to this important problem, Captain James R. Hamby and Lt Galen J. Guillory directed their thesis research to developing a functional model of the Motorola MC68000

microprocessor within the "data-poor" environment just described. Documented in their joint thesis entitled "Architectural Analysis and Modeling of A Motorola MC68000 Microprocessor," a functional model of the MC68000 was developed without the aid of any manufacturer's schematics or other technical data not readily available to a retail purchaser of the system (8:I-6). By successfully modeling the MC68000, Captain Hamby and 1Lt Guillory hoped to demonstrate that not only could a model be developed within the information constraints, but that such a model could also be constructed in an efficient and structured manner, within a reasonable period of time, and without encountering overwhelming technical difficulties.

A functional level model describes the register transfer operations within a device. It enables sytems developers to observe the internal timing and control of logic and register transfer operations long before the microprocessor is included in production systems. Because the detailed gate circuitry is not modeled, functional models are relatively easy to implement, understand, and maintain.

There were two basic approaches that Hamby and Guillory could have taken to analyze and develop a model of the MC68000. One commonly used method requires that the microprocessor be disassembled. During states of disassembly, electron microscope photographs are taken so that the actual circuitry of the chip can be reconstructed

from the photographs. A model can easily be constructed from the resulting logic diagrams and microcode. Although this method produces a very accurate model, it is a very time-consuming and complex process (8:I-8).

An untried, alternative approach required that the timing and voltage levels of the MC68000's pin signals be analyzed while the processor was in operation. The functions performed by the processor could then be modeled using a computer hardware design language. This approach promised faster and more efficient model development, but the accuracy of the resulting model was uncertain. Captain Hamby and Lt Guillory used this second, unchartered modeling approach to build their functional model.

Now that a functional model of the MC68000 has been developed within the imposed constraints, some basic questions naturally arise. Is this "blackbox" approach to microprocessor modeling a sound one? Can an accurate and complete functional model of a microprocessor that expresses the timing, control, parallelism, microprogramming, and other internal operations of today's complex microprocessors be developed by examining input and output signals only? If deficiencies are inherent in this modeling approach, can they be corrected, neglected, or compensated for? Or, are they numerous and significant enough to eliminate this approach as a viable modeling technique in favor of the first, more complex approach? Answers to these questions are essential before this approach can gain acceptance as

the solution to the modeling dilemma confronting the Air Force and other DoD agencies.

#### <u>Problem</u>

This research objective was to evaluate the approach to microprocessor modeling chosen by Captain Hamby and 1Lt Guillory by simulating their model and then analyzing the simulation results against the data they observed during the operation of an actual processor under equivalent conditions. The adequacy of the model will mirror the viability of their approach.

#### <u>Scope</u>

Due to time constraints, Captain Hamby and lLt Guillory did not model the entire microprocessor. Portions of the MC68000 modeled include the read and write bus cycles, representative instruction types, and exception processing sequences (8:II-1). The current model was not extended or optimized, nor were other microprocessors modeled so that broader inferences regarding the effectiveness of this approach to microprocessor modeling could be made. All effort was focused on examining and drawing conclusions from the existing partial model. Because this research yielded positive results, additional research aimed at completing the existing model as well as modeling other architectures will more conclusively demonstrate the practicality and applicability of this modeling approach.

#### Assumptions

N.mPc (network of microprocessors) is a register transfer level (RTL) simulation system that has been successfully used by government and industrial engineering shops in designing VLSI and multiple microprocessor systems (5:76). The validity of this research was heavily dependent upon a simulation package that is efficient, reliable, and most important, comprehensive and accurate. Because N.mPc was the only RTL simulation package available for this research, and its performance had not been personally observed, texts, periodicals, and the developer's documentation were used to vouch for its worthiness. Subsequently, an up-front assumption was that N.mPc would perform well, and it did.

#### Summary of Current Knowledge

Most (if not all) microprocessors have been modeled with computer hardware design languages, and many have been simulated with N.mPc. As a result, MC68000 simulations are available from which comparisons can be made to help determine the accuracy of the model constructed by Captain Hamby and 1Lt Guillory. However, the significance of this research is not centered around the simulation of their model, but rather their approach to model development. Up to now, attempts to develop functional microprocessor models using their "blackbox" approach have been negligible. If their approach can be validated, then this technique will become a great boon to governmental agencies and commercial

businesses employing microprocessor technology.

#### Approach

The approach to evaluating their modeling technique was basically sequential in nature. The simulation, and the subsequent evaluation and documentation of its results followed periods during which the Motorola MC68000 microprocessor, the N.mPc simulation package, both the CDL and ISP' computer hardware design languages, and the MC68000 Educational Computer Board (ECB) were learned. The solution steps to this research problem were:

1) Before the N.mPc software could be used to simulate the "Hamby and Guillory" model, it was first brought "on-line". The package had been delivered to AFIT via tape, but was not yet operational. Using the system documentation provided (i.e., installation and user's manuals), the system was successfully installed on our SSC VAX 11/780 for this thesis effort.

2) Captain Hamby and 1Lt Guillory selected the Computer Design Language (CDL) to describe their model because it was relatively simple to use and understand, and they were familiar with its structure. However, to simulate a microprocessor using N.mPc, it had to be described with a variation of the Instruction Set Processor (ISP) hardware design language. Therefore, both the ISP' and CDL hardware design languages had to be mastered before the necessary conversion could be accomplished.

3) Once an ISP' model was constructed, the operational

1-6

N.mPc simulator was used to exercise the model to generate an operational scenerio of the MC68000 as it executed the same instruction sequences selected by Hamby and Guillory. Chapter VI of their thesis outlines these instructions.

4) The simulation results were then compared with the ocumented logic analyzer signals that described the ECB's MC68000 when executing equivalent instruction sequences. A functionally correct model would accurately project all event occurrences on the system bus. The simulated results should have coincided with that of the physical hardware at each clock cycle (7:459). Any differences required that the model be carefully examined for errors. If the model's microinstruction sequences were not at fault, then the microprocessor's actual operation was again monitored to determine if the logic analyzer data was incorrect. The 68000's ability to prefetch instructions and generate vectors were expected to be likely causes of model errors. Since the prefetch occurs in parallel with instruction execution, it was difficult for Hamby and Guillory to simultaneously monitor both events. The actual generation of vectors was difficult to analyze because this event is totally internally-accomplished (8:V-1,V-2). The time required to complete this portion of the research depended its own "trouble-shooting" session. Once all of the differences had been reconciled, the corrected model was simulated to produce a valid operational scenerio. The

final product of this step was a model that accurately reflected the MC68000's actual operation, a detailed log of any deficiencies detected, the source of these deficiencies, the corrections made, and an assessment of each deficiency's overall impact on the model.

5) Finally, the overall effectiveness of the model was assessed and documented based on the types and numbers of errors encountered, especially those that had a significant bearing on the feasibility of the modeling approach under study. Although this thesis played the "devil's advocate" and concentrated fully on reporting obstacles that may hinder or prohibit this approach from being used, the positive attributes of this model and approach are also fully documented.

#### Overview of Presentation

Chapter II next outlines the requirements of this thesis in detail. To familiarize the reader with both the Motorola MC68000 and the N.mPc simulation package, Chapters III and IV provide brief descriptions of each. Chapter V details the CDL-to-ISP' model transformation process. The N.mPc simulation of the MC68000 model and the analysis of its results are presented in Chapter VI. Finally, Chapter VII contains several conclusions and recommendations and is followed by a short chapter that documents the time spent on each phase of this thesis project.

#### II. <u>Requirements</u>

#### Introduction

This chapter elaborates further on the research approach by outlining the requirements of this project in detail. As mentioned, this effort required that the following five objectives be achieved;

1) install the N.mPc simulation package;

 transform the existing CDL models into equivalent, simulatable ISP' models;

 develop a simulation strategy that enables the observation of those same signals as monitored and documented by Hamby and Guillory;

 simulate the models and then analyze and report the results, and finally;

5) prepare a detailed time log of all work associated with this effort.

#### N.mPc Installation

Release II of N.mPc was on-loaded onto AFIT'S SSC VAX 11/780 from its delivered magnetic tape medium. After being on-loaded, the necessary directory structuring and file relocation was accomplished before the system could be brought on-line and operationally certified. Once operational, all unneccessary software such as documentation, superfluous ISP' library models, and test programs were removed to minimize N.mPc's demands on the VAX's limited storage space. N.mPc's system protection

II-l

mechanisms were also then reconfigured to enable access from this and other interested user's login directories.

#### Model Transformation

Because the scope of Hamby and Guillory's research did not include consolidating or generalizing their numerous instruction descriptions, they in effect developed a single model of the MC68000 hardware elements that was accompanied by multiple, independent models of the following instructions and exceptions: MOVE, JMP, ADD, BEQ, BTST, Illegal Instruction, and Address Error. These models could be individually appended to the lone hardware description to form individually simulatable instructions and exception conditions.

To simplify the model transformation process, this same level of development was preserved. A single ISP' description of the hardware elements was developed to support multiple instruction or exception processing models. This "multiple model" approach simplified model development, made the size of the model manageable, aided in the debugging process, and helped approximate a one-to-one correspondence between CDL and ISP' statements so that model equivalency could more readily be established.

In order to execute the assembly language test routines on the MC68000 ISP' model, the 68000's instruction set had to be described via N.mPc's assembler component, Metamicro. Metamicro allows its users to define the structure and semantics of the target processor's instruction set so that

II-2

source programs designed to run on that processor can be written and assembled. A second N.mPc component, the Linking/Loader, then allows the user to load programs assembled by Metamicro into the microprocessor's simulated memory for execution. Rather than develop auxillary Metamicrc and Linking/Loader routines to construct a workable simulation, these routines were extracted from N.mPc's microprocessor library. With minor modifications, they supported the assembling and loading of the test routines into the MC68000 model.

#### Simulation Strategy

To develop their models, Hamby and Guillory used a logic analyzer to monitor numerous MC68000 signals that provided information pertinent to instruction processing. These signals varied slightly, depending on which instruction or exception sequence was modeled, but at most included the following 20 signals:

| 1  |   | FC0   |
|----|---|-------|
| 2  | - | FC1   |
| 3  | - | FC2   |
| 4  | - | DTACK |
| 5  | - | R/W   |
| 6  | - | LDS'  |
| 7  | - | UDS'  |
| 8  |   | AS    |
| 9  | - | D0    |
| 10 | - | D1    |
| 11 | - | D2    |
| 12 | - | D3    |
| 13 |   | D4    |
| 14 | - | D5    |
| 15 | - | D6    |
| 16 | - | D7    |
| 17 | - | רא    |

· II-3

These signals were examined on both the positive and negative transitions of each clock signal to emulate a two-phase clock and therefore increase the operational resolution of their model's timing. To accurately compare and contrast the simulation results with the observed data, it was essential that a simulation strategy be developed for each instruction or exception sequence that enabled the observation of these same signals at the positive and negative transitions of each simulated clock cycle.

#### Simulation Analysis

The methodology of the simulation analysis phase has been carefully documented in steps 4 and 5 of the research approach (pages I-7 and I-8) and will not be heavily expanded here. However, it should be noted that existing models of the MC68000 that are resident in N.mPc's microprocessor library were used in conjunction with the documented logic analyzer results and ECB operation to assist in the identification of any model discrepancies and their corresponding remedies.

#### Detailed Time Log

As done during Hamby's and Guillory's thesis effort, a detailed time log was maintained and then analyzed at the conclusion of this project. It too includes information on the time spent during each phase of this project such as

II-4



#### III. Introduction to the Motorola MC68000 Microprocessor

#### Introduction

A basic understanding of the M68000's architectural features and its capabilities will prepare the reader for the material of later chapters that describe the development and simulation of the M68000 model. This chapter introduces the M68000 with descriptions of its signals, register organization, instruction set, system architecture, data types, and addressing modes.

#### M68000 Introduction

The MC68000 is a 16-bit microprogrammed microprocessor with a 32-bit internal architecture. First introduced by Motorola in late 1979, this VLSI microprocessor combines state-of-the art technogy (HMOS) and advanced design techniques to achieve very fast processing speeds and high circuit densities (11:1). The chip contains approximately 68000 transistors (hence it's name) and is available in several different operating frequency versions. The 4, 6, 8, and 10-MHz versions have respective clock cycles of 250, 167, 125, and 100 ns.

The 68000's microprogrammed architecture makes future enchancements easy to accomplish. The first version, the MC68000, implements only that subset of the complete 68000 architecture that is allowed by current technology constraints. The 68000's design specifies several features, such as floating-point and string operations, that are not

III-l

#### Signal Description

The 68000 is packaged in a 64-pin DIP (dual in-line package) as illustrated in Figure III-1. The 64-pin count is significantly greater than the conventional 40-pin microprocessors. To achieve greater data transfer rates, is commonly done. The 64 pins can be functionally broken down into the following groups: 23 for the address bus, 16 indicate the processor state, three for system control, and three for MC6800 peripheral control. The remaining five are (Figure III-2). Although the internal data paths are 32 bits wide, packaging limitations constrain the number of data pins to 16 and additional operations are required to transfer more than a 16-bit word. The 23 address lines (Al-A23) enable the 68000 to directly address eight megawords of memory space. Individual bytes are addressed via two control lines: the upper and lower data strobes (UDS' and LDS') (signals followed by a "'" are active low). When UDS' is low,

| 0-12-0                                                                                                                                  | ಕಿದ್ದಾನ         |
|-----------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| D3 🖬 2                                                                                                                                  | ec⊑cs           |
| D2 - 3-                                                                                                                                 | £2D07           |
| DICI                                                                                                                                    | 61 🗖 D6         |
| DO EIS                                                                                                                                  | ဆေညာစခ          |
| ASLO                                                                                                                                    | အညာသက           |
|                                                                                                                                         | 56 <b>⊨</b> ⊃11 |
| IDS CAB                                                                                                                                 | 57 🗖 0.2        |
| R/W 09                                                                                                                                  | 56 - 2013       |
| DIACK CID                                                                                                                               | <b>ビ口014</b>    |
| <u> <u> </u><u></u><u></u><u></u><u></u><u></u><u></u><u></u><u></u><u></u><u></u><u></u><u></u><u></u><u></u><u></u><u></u><u></u></u> | 54 D D 15       |
| BGACE 512                                                                                                                               | ырсиз           |
| BREIS                                                                                                                                   | 52 A 33         |
| VCC 14                                                                                                                                  | 51 A22          |
|                                                                                                                                         | 50 A21          |
| GNDEIL                                                                                                                                  |                 |
| HALT                                                                                                                                    | 48 - 420        |
| RESET                                                                                                                                   | 47 A19          |
|                                                                                                                                         | 46 A18          |
| E [] 10                                                                                                                                 |                 |
| VPAL 21                                                                                                                                 |                 |
| EERS 22                                                                                                                                 |                 |
|                                                                                                                                         |                 |
| 171 11-124<br>1615 mins                                                                                                                 |                 |
| RECEIPS                                                                                                                                 |                 |
|                                                                                                                                         |                 |
| FCDTTOF                                                                                                                                 |                 |
| A 1 ml 24                                                                                                                               | 20 H A8         |
|                                                                                                                                         | 35 7 47         |
|                                                                                                                                         |                 |
|                                                                                                                                         | 27 Jac          |
| Luj 24                                                                                                                                  |                 |

٠.

1

Figure III-1. M68000 Pin Out Diagram (1:1)



Figure III-2. Input and Output Signals (11:33)

data is transferred on lines D8-D15 of the data bus. If LDS' is low, then data is transferred on lines D0-D7. Finally, if both UDS' and LDS' are low, data is transferred on all 16 data lines.

The 68000 can be interfaced with either asynchronous or synchronous devices and has a separate set of control lines for each. It has three control lines to interface with synchronous peripheral devices in the MC6800 family. They are: enable (E), valid peripheral address (VPA'), and valid memory address (VMA'). The address strobe (AS'), read/write control (R/W), data transfer acknowledge (DTACK'), as well as UDS' and LDS' are used to communicate with asynchronous devices.

Three function code lines (FCO, FC1, and FC2) inform external devices whether the 68000 is in a user or supervisor state. They also indicate the type of cycle currently being executed. An external device such as a memory management unit (MMU) can use these signals to ensure that its operations are conducted when the 68000 is in the proper state. These function control lines can also be decoded to extend the 68000's memory space from 16 megabytes up to 64 megabytes (22:260).

The system control lines are used to halt or reset the processor as well as inform the 68000 of bus errors. The three interrupt control pins carry the priority level of a device requesting interrupt service.

#### Register Organization (22:229-232)

The MC60000 provides 17 32-bit general-purpose registers, a 32-bit program counter, and a 16-bit status register as illustrated in Figure III-3. Eight of the general-purpose registers are data registers, seven are address registers, and two are system stack pointers (user and supervisor). The eight data registers can be used to perform byte, 16-bit word, or 32-bit longword operations. When a data register is used as either a source or destination operand, only the appropriate low-order portion is changed, the remaining high-order portion is left unchanged. All data registers can also function as index registers under programmer control.

.



<u>- - - -</u>

Figure III-3. Register Organization (21:45)

The seven address registers are normally used for word or longword address operations. However, all can also function either as base registers, index registers, or software stack pointers. The address registers do not support byte operations. When an address register is a source of an operand, either the entire low-order word or the entire longword is used depending on the operation size. When used as the destination of an operand, the entire register is affected, regardless of the operation size. If the Although the program counter is 32 bits long, only the low-order 24 bits are currently being used. The high-order byte is ignored. Bits 1-23 of the PC are routed to chip's 23 address lines. Bit 0 of the PC is internally encoded with the operand length in the instruction being executed to generate the two data strobe signals UDS' and LDS' described earlier.

The two independent system stack pointers share address A7. The A7 address register acts as a user stack pointer when the 68000 is in a user state, and as a sytem stack pointer when the 68000 is in a supervisor state.

The status register is divided into a system byte and a user byte. The user byte contains five condition code bits (0-4) to record the status of completed operations. They are: carry (C), overflow (V), zero (Z), negative (N), and extend (X). The extend bit acts as a carry for multiprecision arithmetic operations. The status register's system byte has three fields. The interrupt mask is contained in bits 8-10 and provides eight levels of interrupts. With the exception of level seven, all interrupt levels less than or equal to the mask are ignored. Critical interrupts such as system power failures are assigned level seven. The supervisor (S) bit is used to determine whether the 68000 is in a user or supervisor state. The trace mode (T) bit will allow the 68000 to

single step through a program. After each instruction is executed, the 68000 will vector to a special user-written routine that examines the contents of a memory location, register, or performs other debug operations.



Figure III-4. Instruction Cache (12:3)

#### System Architecture

The 68000 employs a pipelined architecture in which the instruction fetch, decode, and execute cycles are fully overlapped. An attempt has also been made to minimize delays in branching by prefetching instructions associated

with the most likely branch condition (23:29). Additionally, the MC68020 contains an on-board instruction cache that allows repeated instruction streams to execute significantly faster while freeing the external bus for other processors (Figure III-4).

Pipelined processing is accomplished via the three-sectioned Execution Unit (Figure III-5). Each section contains in its register file some of the 17 general-purpose registers described earlier, as well as others transparent to the user. Each section also contains its own 16-bit ALU. These three sections are dynamically configured by the microcode (they can be isolated or concatenated as necessary) to provide simultaneous address and data processing (15:37).

Instructions are brought in through the 16 data lines into the Instruction Register and Instruction Decode Unit. The Instruction Decode Unit generates an address for the microinstruction in the Micro Control Store. Timing-independent information is sent directly to the Execution Unit.

The Control Store is a two-level structure containing a vertically-microcoded Micro Control Store and a horizontally microcoded Nano Control Store. The Micro Control Store generates a 9-bit address for the nanoinstruction in the Nano Control Store, as well as issues branching signals to the Instruction Decode Unit to cause its next address to be incremented or altered based on conditions received from



. ۰., .

.

· · · ·

· · -

.

Figure III-5. MC68000 Architecture (23:9)

۰.

.

the Execution Unit. The Nano Control Store houses 280 68-bit control words that directly control the Execution Unit. Approximately 2880 bytes of control store is used, about half that of an equivalent single level implementation (23:29).

The 68000 does not include an on-board memory management unit (MMU). It can be operated with or without one. However, the MC68451 MMU can be interfaced with the 68000 to provide for vertical addressing, segmentation, and memory protection for multiprocessing environments.

#### Data Types and Organization

The 68000 can operate on five basic data types: bits, bytes, BCD digits, 16-bit words, and 32-bit longwords. These data types are stored in memory as depicted in Figure III-6. Bytes are individually accessible. The high-order byte is assigned its word's even address (Figure III-7) while the low-order byte has an odd address that is one more than its word's. Instructions and data are accessed only on

|           |    |    |           |    | 2 154-101 | ا<br>دىن ر | iaminai<br>ad Datin | Dale<br>Nal Dij | jas = 1 | 8976 |   |   |   |   |   |
|-----------|----|----|-----------|----|-----------|------------|---------------------|-----------------|---------|------|---|---|---|---|---|
| 15_       | 14 | 13 | 12        | 11 | 10        | 9          | 8                   | 7               | e       | 5    | 4 | 3 | 2 | 1 | 0 |
| MSD BCD 0 |    |    | ECD 1 LSD |    |           | BCD 2      |                     |                 | BCD 3   |      |   |   |   |   |   |
| BCD 4     |    |    | ECD 5     |    |           | 8 CD 6     |                     |                 | BCD 7   |      |   |   |   |   |   |

Figure III-6. Data Organization In Memory (10:2-2,2-3)
| ॅ 🏎 🗐 🏎 ५ ६ ६ ६ ६ ६ ६ ६ ६ ६ ६ ६ ६ ६ ६ ६ ६ ६ ६                                                                                       | 5<br>6<br>5<br>6<br>5<br>6<br>5<br>9<br>115<br>6<br>5 | 4 3<br>Byte 1<br>byte 3<br>4 3 | 2     | 1 0<br>1 C<br>LSP |  |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|--------------------------------|-------|-------------------|--|--|--|--|
|                                                                                                                                     | 6 5<br>13<br>6 5<br>13<br>6 5<br>9 Its<br>8 5         | 4 3<br>Byte 1<br>Byte 3<br>4 3 | 2     | 1 0<br>1 C<br>LSB |  |  |  |  |
| ॅ <sup>15</sup><br><u><u></u></u><br><u></u><br><u></u><br><u></u><br><u></u><br><u></u><br><u></u><br><u></u><br><u></u>           | 15<br>6 5<br>13<br>6 5<br>9 115<br>8 5                | 4 3<br>Byte 1<br>Byte 3<br>4 3 | 2     | 1 0<br>1 C<br>LSE |  |  |  |  |
| ॅ 11 11 11 11 11 11 11 11 11 11 11 11 11                                                                                            | 6 5<br>15<br>6 5<br>9 Its<br>8 5                      | 4 3<br>Byte 1<br>Byte 3<br>4 3 | 2     | 1 0<br>1 C<br>LSE |  |  |  |  |
| ॅ ඁ î                                                                                                                               | 5 <u>6 5</u><br>Bits <u>6 5</u>                       | Byte 1<br>Byte 3<br>4 3        | 2     | 1 C<br>LSE        |  |  |  |  |
| ॅ <sup>15</sup>                                                                                                                     | 6 5<br>6 5<br>9 its<br>6 5                            | Eyie 3<br>4 3                  | 2     | 1 C<br>LSP        |  |  |  |  |
| 塙,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,                                                                                            | 15<br>65<br>9<br>15<br>15<br>85                       | 4 3                            | 2     | 1 C<br>LSB        |  |  |  |  |
| ॅ <sup>15</sup> 11 10 9 9 7                                                                                                         | 6 5<br>9:ts<br>6 5                                    | 4 3                            | 2     | 1 C<br>LSE        |  |  |  |  |
| ॅ <sup>1</sup> | Bits<br>8 S                                           |                                |       | LSB               |  |  |  |  |
| ॅ <sup>1</sup>                                                                                                                      | Bits<br>8 S                                           |                                |       |                   |  |  |  |  |
| ॅ:                                                                                                                                  | Bits<br>8 5                                           |                                |       |                   |  |  |  |  |
| 뒵                                                                                                                                   | Bits<br>6 5                                           |                                |       |                   |  |  |  |  |
| ॅ do                                                                                            | 8 5                                                   |                                |       |                   |  |  |  |  |
| ॅ                                                                                                                                   |                                                       | 4 3                            | 2     | 1 0               |  |  |  |  |
| ॅ <text></text>                                                                                                                     |                                                       |                                |       |                   |  |  |  |  |
| ॅ<                                                                                                                                  |                                                       |                                |       |                   |  |  |  |  |
| ే                                                                                                                                   |                                                       |                                | ····· | LSB               |  |  |  |  |
| ే () () () () () () () () () () () () ()                                                                                            |                                                       |                                |       |                   |  |  |  |  |
| ే <text></text>                                                                                                                     | ······.                                               |                                |       |                   |  |  |  |  |
| ే ((((((((((((((((((((((((((((((((((((((                                                                                            |                                                       |                                |       |                   |  |  |  |  |
| ే.<br>                                                                                                                              |                                                       |                                |       |                   |  |  |  |  |
| ే.                                                                                                                                  |                                                       |                                |       |                   |  |  |  |  |
| ే <b>(</b> )<br>()<br>()<br>()<br>()<br>()<br>()<br>()<br>()<br>()<br>()<br>()<br>()<br>()                                          | <b>6</b> 5                                            | 4 3                            | 2     | 1 0               |  |  |  |  |
| ే in                                                                                            |                                                       |                                |       |                   |  |  |  |  |
| ే ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( (                                                                                           |                                                       |                                |       | ·                 |  |  |  |  |
| ే                                                                                                                                   |                                                       |                                |       | LSB               |  |  |  |  |
| ే<br>                                                                                                                               |                                                       |                                |       | ·                 |  |  |  |  |
| ే <page-header></page-header>                                                                                                       |                                                       |                                |       |                   |  |  |  |  |
| ే () () () () () () () () () () () () ()                                                                                            |                                                       | ,                              |       |                   |  |  |  |  |
| ే                                                                                                                                   |                                                       |                                |       |                   |  |  |  |  |

Figure III-6. Data Organization In Memory (continued)

even byte boundaries. Longword data occupies two consecutive addresses in memory (1:2).

|    |    |    |            |                                               |    |             |       | ~~~~                                   | 10111 | 4 DIEI4 |        |       |   |   |   |
|----|----|----|------------|-----------------------------------------------|----|-------------|-------|----------------------------------------|-------|---------|--------|-------|---|---|---|
| 15 | 14 | 13 | 12         | 11                                            | 10 | 9           | E     | 7                                      | 6     | 5       | 4      | 3     | 2 | ١ | Ũ |
|    |    |    |            |                                               |    |             | Viord | ana                                    |       |         |        |       |   |   |   |
|    |    | Б  | vie 00     | $\infty$                                      |    | ే           |       |                                        |       |         |        |       |   |   |   |
|    |    |    |            |                                               |    | Vyoro COCO2 |       |                                        |       |         |        |       |   |   |   |
|    |    |    |            |                                               | ే  |             |       |                                        |       |         |        |       |   |   |   |
|    |    |    |            |                                               |    |             | •     |                                        |       | _       |        |       |   |   |   |
|    |    |    |            |                                               |    |             |       | •                                      |       |         |        |       |   |   |   |
|    |    |    |            |                                               |    |             |       | •                                      |       |         |        |       |   |   |   |
|    |    | 8. | ~~ = = = = |                                               |    |             | Ward  | ////////////////////////////////////// | Ł     |         | B.co E | ceree |   |   |   |
|    |    |    | vie err    | · · · · <u>· · · · · · · · · · · · · · · </u> |    |             |       | 1                                      |       |         | Oyle r | rrirr |   |   |   |

Figure III-7. Memory Word Organization (11:14)

### Addressing Modes (20:232-257)

The 68000 offers 14 operand addressing modes giving it a very flexible addressing capability. As Figure III-8 illustrates, these modes fall into six basic groups: register direct, address register indirect, absolute, program counter relative, immediate, and implied.

| ॅं                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ॅiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiii                                                                                                                                                                               |  |  |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| ॅ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Generation                                                                                                                                                                                                             |  |  |  |  |
| 뒵IIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIII                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | EA = Dn<br>EA = Ap                                                                                                                                                                                                     |  |  |  |  |
| 뒵, in initial in | EA = (Next Word)<br>EA = (Next Two Words)                                                                                                                                                                              |  |  |  |  |
| 뒵                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | $EA = (PC) + a_{1C}$<br>$EA = (PC) + (Xn) + a_{5}$                                                                                                                                                                     |  |  |  |  |
| ॅ <list-item><section-header></section-header></list-item>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | $EA = (An)$ $EA = (An), An - An + N$ $An - An - N, EA = (An)$ $EA = (An) + d_{16}$ $EA = (An) + (Yn) + d_{5}$                                                                                                          |  |  |  |  |
| 뒵                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | DATA = Next Word(s)<br>Inherent Data                                                                                                                                                                                   |  |  |  |  |
| 집 IIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIII                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | EA = SR, USP, SP, PC                                                                                                                                                                                                   |  |  |  |  |
| ॅ <list-item><section-header><section-header><table-container><table-container><table-container><table-container>&gt;<br/>O````````````````````````````````````</table-container></table-container></table-container></table-container></section-header></section-header></list-item>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | <ul> <li>d6 = Eight-bit Offset (displacement)</li> <li>d16 = Sixteen-bit Offset (displacement)</li> <li>N = 1 for Byte, 2 for Words and 4 for<br/>Long Words</li> <li>( ) = Contents of</li> <li>= Replaces</li> </ul> |  |  |  |  |

# Figure III-8. Addressing Modes (10:1-5)

III-14

Immediate data addressing is used to specify a constant

data operand as opposed to the contents of a register or memory location. Implicit addressing instructions implicitly refer to the program counter, system stack pointer, user stack pointer, or the status register.

### Instruction Set (22:241-257)

| ॅ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |    |    |    |       |             |                |                     |                    |                      |                    |              |          |   |   |   |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|-------|-------------|----------------|---------------------|--------------------|----------------------|--------------------|--------------|----------|---|---|---|
| 15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 14 | 13 | 12 | 11    | 10          | 9              | 8                   | 7                  | 6                    | 5                  | 4            | 3        | 2 | 1 | 0 |
| ॅ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |    |    |    |       |             |                |                     |                    |                      |                    |              |          |   |   |   |
| ॅ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |    |    |    |       |             |                |                     |                    |                      |                    |              |          |   |   |   |
| ॅ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |    |    |    |       |             |                |                     |                    |                      |                    |              |          |   |   |   |
| ॅ:::::::::::::::::::::::::::::::::::::::                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |    |    |    |       |             |                |                     |                    |                      |                    |              |          |   |   |   |
| ॅ <form>OF COURCES C</form> |    |    |    |       |             |                |                     |                    |                      |                    |              |          |   |   |   |
| _ 15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 14 | 13 | 12 | NSTRU | CTION<br>10 | S<br>OFER<br>9 | UNGLE<br>ATION<br>8 | EFFEC<br>WORI<br>7 | TIVE-A<br>D GEN<br>6 | ADDRE<br>ERAL<br>5 | ESS<br>FORMA | .т<br>Э_ | 2 | 1 |   |

Figure III-9. Instruction Format (10:2-4)

III-16

| M | nemonic                                           | Description                                                                                                                                |  |
|---|---------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|--|
|   | ABCD<br>ADD<br>AND<br>ASL<br>ASR                  | Add Decimal with Extend<br>Add<br>Logical And<br>Arithmetic Shift Left<br>Arithmetic Shift Right                                           |  |
|   | Bcc<br>BCHG<br>BCLR<br>BRA<br>BSET<br>BSR<br>BTST | Branch Conditionally<br>Bit Test and Change<br>Bit Test and Clear<br>Branch Always<br>Bit Test and Set<br>Branch to Subroutine<br>Bit Test |  |
|   | CHK<br>CLR<br>CMP                                 | Check Register Against Bounds<br>Clear Operand<br>Compare                                                                                  |  |
|   | DBcc<br>DIVS<br>DIVU                              | Test Cond., Decrement and Branch<br>Signed Divide<br>Unsigned Divide                                                                       |  |
|   | EOR<br>EXG<br>EXT                                 | Exclusive Or<br>Exchange Registers<br>Sign Extend                                                                                          |  |
|   | JMP<br>JSR                                        | Jump<br>Jump to Subroutine                                                                                                                 |  |
|   | LEA<br>LINK<br>LSL<br>LSR                         | Load Effective Address<br>Link Stack<br>Logical Shift Left<br>Logical Shift Right                                                          |  |
|   | MOVE<br>MOVEM<br>MOVEP<br>MULS<br>MULU            | Move<br>Move Multiple Registers<br>Move Peripheral Data<br>Signed Multiply<br>Unsigned Multiply                                            |  |
|   | NBCD<br>NEG<br>NOP<br>NOT                         |                                                                                                                                            |  |
|   | OR                                                |                                                                                                                                            |  |
|   | PEA                                               |                                                                                                                                            |  |

Figure III-10. MC68000 Instruction Set (10:1-6)

III-18

V1

| Mnemonic                                                 |  |
|----------------------------------------------------------|--|
| SBCD<br>Scc<br>STOP<br>SUB<br>SWAP                       |  |
| TAS<br>TRAP<br>TRAPV<br>TST                              |  |
| UNLK                                                     |  |
| RESET<br>ROL<br>ROR<br>ROXL<br>ROXR<br>RTE<br>RTR<br>RTS |  |

Figure III-10. MC68000 Instruction Set (continued)

Multiprecision arithmetic operations on Binary Coded Decimal numbers can be accomplished with the add decimal

III-19

eventually be microcoded in future versions of the 68000.

III-21

#### IV. Introduction to N.mPc

#### Introduction

N.mPc (PMS notation for "network of microprocessors") was designed and implemented by the Department of Computer Engineering and Science at Case Western Reserve University between 1975 and 1979. Its objectives were to:

2) allow modeling at multiple levels of abtraction;

3) allow changes to topologies and microprocessor descriptions with a minimum of work and expense;

4) not impose any particular design style;

5) include facilities for monitoring and controlling simulations of the target achitectures;

6) be useable by non-hardware specialists; and

7) perform well when simulating and evaluating large architectures (18:1).

The resulting system was written in the programming language C and runs on DEC PDP-11 and VAX computers under the VMS and UNIX (V6,V7, and 4.1 BSD) operating systems. N.mPc consists of six major components: the ISP' compiler,

2) Ecologist. The Ecologist defines the structure of the target system. It uses a system topology file describing the ISP' object modules to be combined to form the simulation program.

The two components used to develop software for the simulation model are:

user can execute on an ISP' hardware engine (5:77).

ę



Ż

و

7



# IV-4

object code into the memory components of the simulation model. Finally, using the Runtime package, the user can simulate and observe the operation of the hardware and software components to test and evaluate the system.

# <u>ISP'</u> (20:1-5)

l) states - the microprocessor's registers are represented by states. Instruction registers, program counters, flags, etc. are declared as states. The following example declares an array of eight registers, each containing 8 bits:

# state D[0:7]<7:0>;

2) memories- random access memories are declared to host the simulated microprocessor's instructions and data. A memory with 64K 16-bit words can be declared with the following declaration:

#### memory M[0:65537]<15:0>;

3) ports - a microprocessor's address bus, data bus, and

ଣ control contr

#### port databus<1:8>;

```
state counter<16>;
main := (
    delay(1);
    counter <= counter + 1
)</pre>
```

ƴ Main in kinaka kinak

In addition to "counter", there exists another 16-bit register "save", and two single-line ports "ck" and "switch". When the leading edge of "ck" occurs, the processor accomplishes one of two possible actions; if switch is true, the registers "counter" and "save" are exchanged and then "counter" is incremented, else "counter" is incremented without a prior register swap. Because ISP' is a register transfer language, assignments are performed concurrently. If not, in the above example the register "save" would receive its old value. The "next" statement enables sequential assignments by causing the preceding assignments to be made. Without it, all three of the example assignments would be made concurrently (if switch were true) and the result in "counter" would be indeterminate. Because the statement "next" is implied at at the end of the "when" process. The "delay" and "wait"

#### <u>Metamicro</u> (16)

Metamicro is a generalized micro assembler which uses a description of a generalized micro assembler as a description of a generalized micro assembler as a description of a generalized micro assemble description of a generalized micro assemble translator which takes a computer instruction in a form understand translator and translator assemble to assemble to assembly and the description by allowing the user to specify the input form, output form, and translation of the target processor's instruction set using Metamicro constructs. This description is then used to assemble applications programs written in the target processor's instruction of the tiltet instruction set using Metamicro description of the tiltet intel be assemble to be a set in the tiltet intel be a set in the tiltet intel be a set in the tiltet intel be a set intel be a set intel be a set intel be a set intel intel be a set intel be a set intel be a set intel be a set intel intel be a set intel be a set intel be a set intel be a set intel intel be a set intel

BOBO instruction set. Even though only two instructions are modeled (Add Register to A (add) and Add Register to A with Carry (adc)), it will serve as an adequate introduction to Metamicro.

inst[3,1]<8> \$ ! three words of eight bits each instr ! default instruction length one = inst[0]<7:6>, ! format op code op = inst[0]<5:3>, ! destruction dst = inst[0]<2:0>\$ ! source scr macro = 0 b &, &, С = 1 d = 2 &, е = 3 δ, h = 4 ٤, = 5 1 æ, m = 6 ٤, а = 7 ٤, sreg(x) = src = x \$ &,add(x) = op = 2;dst = 0;sreg(x) & , ! add reg or mem adc(x) = op = 2;dst = 0;sreg(x) & \$ ! adc req or mem

Figure IV-2. Metamicro Description (19:Chap 2:7)

െ</del> in in in it. It is is is is in the set of t

instr inst[3,1]<8> \$

The name "inst" is used to symbolically reference the instruction. To enable variable length instructions, the maximum instruction word size has been set at three while the minimum is declared to be one ([3,1]). Since the basic word size has been declared to be eight bits (<8>), we can create one, two, or three byte instructions. The \$ character terminates all Metamicro statements. The "!" is used for commenting by causing Metamicro to ignore the remainder of the current line.

u decidación decidación decidación decidación decidación decidación decidación decidación decidación de constatue de constat

| format | qo  | =   | inst[0] | <7:6>,  | 1 | 办的问题。                                   |
|--------|-----|-----|---------|---------|---|-----------------------------------------|
|        | dst | = ` | inst[0] | <5:3>,  | 1 | η ( ) ( ) ( ) ( ) ( ) ( ) ( ) ( ) ( ) ( |
|        | src | =   | inst[0] | <2:0>\$ | I | ş                                       |

<b to the source and destination registers are identified.<br/>
source and destination registers are identified.<br/>
Specifically, the src registers are identified.<br/>
Specifically, the src register is identified by bits 0-2 in<br/>
the first byte of the instruction and the dst register is<br/>
identified by bits 3-5. Finally, the op code is contained in<br/>
bits 6-7.

A macro is used to translate the instruction mnemonics A macro is used to translate the instruction mnemonics developed by the user to correspond with a microprocessor's assembler into statements compatible with Metamicro. A macro element has the following structure:

#### macro\_name = macro\_body &

In the example of Figure IV-2, the macro declaration section begins with the keyword "macro" and forms the bulk of the instruction set description.

```
macro b = 0 &,

c = 1 &,

d = 2 &,

e = 3 &,

h = 4 &,

l = 5 &,

m = 6 &,

a = 7 &,

sreg(x) = src = x $ &,

add(x) = op = 2;

dst = 0;

sreg(x) &, l add reg or mem

adc(x) = op = 2;

dst = 0;

sreg(x) & l add reg or mem
```

Before continuing, it is necessary to introduce an

applications program that can be assembled by the above Metamicro description (19:Chap 2:8).

include 8080.m\$ begin add(b)adc(m) end

adc(m) instruction differs only in that register six identifies the memory location to be added to register zero. The macro sreg(x) is common to both instructions.

### Linking/Loader (17)

l) instr - informs the Linking/Loader of an instruction's size and format;

format - specifies the instruction subfields that
 will be symbolically referenced;

3) mode - describes how referenced labels are resolved

into address operands;

.

4) space - declares available memory space; and

· · ·

5) transfer - provides the Linking/Loader with information pertinent to the relocation of instruction segments.

Figure IV-3 is a generalized Linking/Loader command program for the Intel 8080 microprocessor.

instr inst[3,1]<8>\$ format op = inst[0]<7:6>, dst = inst[0] < 5:3 >, src = inst[0] < 2:0 >, rx = inst[0] < 5:4 >,wdl = inst[0] < 7:0>, wd2 = inst[1]<7:0>, wd3 = inst[2]<7:0>\$ space <0:4095>\$ mode case length eql 3: wd2 = address $wd3 = address^{-8}$ break\$ esac, default: wdl = address\$  $wd2 = address^{-8}$ break\$ esac\$ transfer f new wdl = 0303\$ wd2 = address\$ wd3 = address^-8\$ length = 3\$

Figure IV-3. Linking/loader Command Program (19:Chap 2:10)

The Linking/Loader "instr" and "format" declarations are

equivalent to those of Metamicro that were presented earlier and will not be discussed again here.

The mode declaration is similar to the case statement The 8080 has a single addressing mode, direct address, and it occurs when the instruction is three bytes long െinteriorie interiorie length associated with it and is stored in the variable "length". If this initial expression is true, the second of the label's address and the instruction's third word (wd3) receives the upper eight bits. The "=" means to logically "or" the expression value on the right into the identifier on the left. If the expression on the right exceeds the bit length of the identifier on the left, then only the least significant bits are or'ed. Because "address" is a 32-bit field and wd2 is eight, wd2 receives the eight least significant bits of address. Note that

If the initial case entrance expression evaluated to false, then the default case is entered and words one and two of the instruction (wdl and wd2) would receive the address. This is the case when the label referred to is a data constant (19:Chap2:11).

The space declaration describes the target processor's
memory space. Linking/Loader allocates applications program
instructions assembled by Metamicro into this space. The
space declaration of Figure IV-3 defines a 4k memory.

During the loading process, the Linking/Loader may break a group of logically contiguous instructions into segments and place them into disjoint areas of the target machine's defined memory space. To ensure that target machine instructions appear logically contiguous to the user, when this occurs the Linking/Loader adds a new statement to unconditionally transfer the program flow to the disjoint segments. The Linking/Loader builds this new instruction in accordance with the format specified in the transfer declaration.

#### Ecologist (13)

sections which may or may not be included depending on the nature of the ISP' model.

Ì

l) Signal – A signal is the name of the connection that exists between ISP' ports. The value of a signal is the logical "or " of all the ports tied to it. An example of a signal declaration is:

signal ADDRESS(23), DATA(16), R\_W;

This declaration begins with the keyword "signal" and describes a 23-bit address bus, 16-bit data bus, and a read/write control line.

processor cpu = "M68000.sim";

The keyword "processor" begins the process declaration. At simulation time, the ISP' hardware model will be referred to by the name "cpu". M68000.sim is the UNIX file containing the ISP' compiled output.

time delay 60 ns;

This declaration will cause each unit of delay in the 1SP' model to correspond to 60 ns.

.

```
connection abus = ADDRESS,
    dbus = DATA,
    rw = R_W;
```

would connect the ports abus, dbus, and rw to the signals declared earlier. Note that ports and signals must be the same width to enable connection.

initial mem = sortimage;

Figure IV-4 illustrates a topology file that describes a simulation comprised of a Motorola 68000 with an external memory that will be loaded with the sorting algorithm "sortimage" introduced above.

| - |                                              |                                                                                    | <br>                                                                                           |                                                                                                                                                 |
|---|----------------------------------------------|------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
|   | ՄАВ СТАВАСТАВАТАВАТАВАТАВАТАВАТАВАТАВАТАВАТА | S(23),<br>6),                                                                      | !<br>!<br>!<br>!<br>!                                                                          | Address Bus<br>Address Strobe<br>Data Bus<br>Upper Data Strobe<br>Lower Data Strobe<br>Data Transfer Acknowledge<br>Read/Write<br>Function Code |
|   | ğu de    | Cpu<br>60 ns;<br>ADDRESS<br>AS<br>DATA<br>UDS<br>LDS<br>DTACK<br>R_W<br>FC         | "m68000b,<br>ADDRESS,<br>AS,<br>DATA,<br>UDS,<br>LDS,<br>DTACK,<br>R_W,<br>FC;                 | .sim";                                                                                                                                          |
|   | γγγγγγγγγγγγγγγγγγγγγγγγγγγγγγγγγγγγγγγγ     | mem<br>100 ns;<br>ADDRESS<br>AS<br>DATA<br>UDS<br>LDS<br>DTACK<br>R_W<br>FC<br>mem | <br>"m68000br<br>ADDRESS,<br>AS,<br>DATA,<br>UDS,<br>LDS,<br>DTACK,<br>R_W,<br>FC<br>sortimage | n.sim";<br>2;                                                                                                                                   |

Figure IV-4. Motorola MC68000 Topology File

# Simulated memory Processor (13:10,11)

The Linking/Loader produces a memory image file

่

# Runtime (14)

### examine cpu:abus

will display the current value of the abus port from
the ISP' process cpu. Note that the ISP' process name will be one
specified in the topology file.

 deposit - deposit allows the user to write a value into a state, port, or memory location. For example,

# deposit 0b00011011 cpu:ir

#### states cpu

This command will display the contents of all registers on board the processor "cpu".

 ports - performs the same function for ports as states does for registers.

5) memory - memory is used to examine multiple memory locations. For example,

# memory cpu:mem 100 110

will display locations 100-110 of a memory named "mem"
will display locations 100-110 of a memory named "mem"
that has been declared in the ISP' process cpu. Note that numbers
beginning with 1-9 are assumed to be decimal.

# display cpu:ir

will cause the contents of the register ir to be displayed each time it is written to. Also included in the display will be the current simulation time.

 7) bkpt - the bkpt (breakpoint) command causes the simulation to stop when a particular time or condition exists. For example,

### bkpt 1250

will cause the simulation to stop in 1250 ns so that the user can monitor the simulation.

 repeat - if the repeat command prepends bkpt then the breakpoint will be continually repeated. For example,

### repeat bkpt 1250

will cause the simulation to stop every 1250 ns.

10) quit - the command quit terminates a simulation.

## Local System Access

Appendix A provides the interested reader with information to supplement departmental N.mPc documentation packages to allow access and use of the system as locally installed. Included is:

 a functional description of each of N.mPc's major components and simulation files,

2) an organizational representation of each N.mPc component along with their input and output files,

3) instructions for accessing the system,

4) a listing of N.mPc's directory structure that includes its microprocessor library, and

5) an example of a N.mPc simulation output product.

model the MC68000 for simulation.

# CDL/ISP' Comparison

/ctrl\*K(4)\*P(1)/ PFR <- EXDBUF
/ctrl\*K(4)\*P(2)/ ASN <- 1, LDSN <- 1, UDSN <- 1, T <- 0,
IR <- PFR, PC <- PCadd2</pre>

ろ, contened energy energy

V-2
these two execution statements would have no effect on the timing of the microoperations. Whenever the conditions of the label are satisfied, its microstatements are executed. In contrast, here is the ISP' equivalent:

```
if ctrl and K eql 4
  (
    wait (P1:lead);
    PFR = EXDBUF;
    next;
    wait (P2:lead);
    ASN = 1;
    LDSN = 1;
    UDSN = 1;
    T = 0;
    IR = PFR;
    PC = PC + 2;
    next
  );
```

Being a "procedural" language, the sequential ordering of ISP' statements implies an explicit ordering of its activities, and the activation of activities is conditioned by the completion of the preceding ones (2:138). If the conditions of the "if" statement are satisfied, then the microstatements enclosed in parenthesis are executed. Also, should the order of the two "wait" statements be changed, then the execution of their following microstatements will be reversed. This is an undesirable result since we want PFR (prefetch register) to receive EXDBUF (external data buffer) before it is loaded into IR (instruction register). In CDL, there is no provision for the partitioning of a hardware description into blocks of related execution statements to reflect a particular organization or hierarchy

of activities (2:144). Execution statements have a sequential appearance with two columns formed by their labels and microstatements (2:138). ISP' descriptions follow the structure of C programs and possesses many of its high-level programming constructs (e.g., case, do-until, while). As such, it does not impose a rigid repetitive design style upon the user. The above example also highlights several other major differences between CDL and ISP'.

Because CDL labels identify the conditions under which their associated microstatements are performed, there is a clear delineation between data and control. Special control variables separated by slashes specify the conditions necessary to execute the microstatements. Sequencing through microstatements is accomplished by modifying the control variables in the label. If the label's control expression evaluates to true, then its accompanying microstatements are executed, otherwise they are ignored. In contrast, ISP's conditional statements form the equivalent of labels. Delinear ambiguity exists between the conditional expressions representing control, and their dependent microstatements. The conditional test is performed and the following microstatements are either executed or skipped depending on the outcome. Additionally, in CDL, timing is provided by including in the label a specialized control component, the clock. The following example from Hamby and Guillory's model declaration section

## illustrates clock usage:

Clock, P(1-2) \$ two phase clock

This clock statement declares a two-phase clock to provide a two-phase clock cycle for their MC68000 model (4:6). As a result, clock pulses P(1) and P(2) alternate values between one and zero in accordance with a frequency specified by the host simulation package. Action by this independent activity automatically modifies label control expression to direct the timing of microstatement executions. ISP' has no such clock structure. As with control, the timing of its microstatements are provided by conditional statements in conjunction with several specialized monitoring facilities such as the "when" process and "wait" statement. Below is an example of a wait statement taken from the previous ISP' example.

## wait(Pl:lead); PFR = EXDBUF;

In this example, the wait statement will cause the process to halt execution until the port signal "Pl" transitions high. The microstatements following it will not be executed until this occurs. Similarly,

```
when(ck:lead) :=
    (
    address = adr_reg;
    read = lo
    )
```

will cause the series of statements associated with the "when" process to be executed when "ck" transitions high.

However, these two monitoring facilities can only be used in conjunction with external signals (port signals) and cannot be triggered by local state change (change in the state of an internal register). This requirement prohibits their use when a single hardware component is modeled.

ISP' also provides a "delay" statement to cause a process to wait a specified number of time units before resuming. The time specified is independent of real time, rather it is a simulated time that corresponds to the real time in the system being simulated. The delay statement is not used to direct the execution of microstatements but is used to specify the simulation time in which a microstatement is executed. Whether a microstatement is executed or not is dependent upon the outcome of prior conditional statements.

Another of the specialized structures available in CDL but not found in ISP' is the "decoder". As does its real word counterpart, CDL's decoder translates the binary value of its inputs into a single output signal (4:6). For example, the MC68000 decoder statement

Decoder, K(0-255) = T(0-7)

specifies a 8 x 256 decoder, K. Its eight inputs are attached to register T (which had been previously declared); thus, the binary value of T will determine which of K's 256

output lines becomes high. Decoder output is often used in a label's control expression to direct the sequencing of CDL microstatement execution. Another example taken from the MC68000 CDL model depicts this process.

/ctr1\*K(1)\*P(2)/ T <- CountupT /ctr1\*K(2)\*P(1)/ IF (DTACKN = 0) THEN (T <- CountupT)</pre>

From this example, it is easy to see that the output of decoder K controls the seqencing of these two microstatements. Since the decoder K is attached to register T, when the operator "Countup" in the first microstatement increments register T, K(2) will become high and provide the potential for the next microstatement to be executed. While such a combinatorial circuit is not provided by ISP', it can be duplicated by the following microstatement:

## K[T]

if registers T and K have previously been declared as follows:

# state T<8:0>, K[0:255];

In this example, T has nine bits because the most significant bit is interpreted by ISP' as the sign bit.

A statement found in ISP' but not CDL is the "next" statement. As mentioned in the previous chapter, the next

statement forces sequentiality. All assignments preceding it are performed concurrently. In a CDL execution statement, all microstatements associated with the statement label are executed concurrently. Sequentiality is achieved via decoders and clock pulses in the label's control expression. Similarly, ISP' uses its next statement to support both sequential and concurrent operations. By following a group of assignment statements with a "next" statement, sequential execution of concurrent statement groups can be achieved.

Another special CDL statement not provided by ISP' is the "switch" statement. It is used to represent the manual switches of a computer's control panel used by the operator (4:4). The declaration

## Switch, POWER(ON, OFF)

models a power switch that can either be on or off to control power-up/power-down microoperations. If in this example,

/POWER(ON) / R <- 0, A <- 1

the simulated power switch is set on, then the accompanying microstatements will be performed.

Finally, there are several structure declarations that are basically the same in both ISP' and CDL, but they possess minor differences worth identifying. First, a memory is declared in ISP' by specifying the keyword

"memory" followed by its identification and size specification. For example,

memory Mem[0:4095]<7:0>;

describes a 4 kbyte memory identified as "Mem". An equivalent CDL memory statement would be

Register, MAR(0-12)Memory, Mem(MAR) = Mem(0-4095,0-7)

Note that the CDL declaration specifies a memory address register (MAR) via subscript. This is because each memory is associated with a specific address register and it must be used to address a given location (4:4). In contrast, ISP' memories are not bound to a specific register. It enables its users to arbitrarily select any of its available registers to index into memory at any given time.

To represent register subfields, CDL uses the "subregister" statement while ISP provides a "format" statement. For example, here are statements in both CDL and ISP' to identify the subfields of a instruction register:

ISP'

state format

OPCODE = IR<12:15>, OPER1 = IR<6:11>, OPER2 = IR<0:5>;

IR<0:15>;

CDL

| Register,    | IR(0-15)    |   |            |
|--------------|-------------|---|------------|
| Subregister, | IR (OPCODE) | = | IR(12-15), |
|              | IR(OPER1)   | = | IR(6-11),  |

## IR(OPER2) = IR(0-5)

The major difference is that CDL does not allow independent naming of its subregisters. The parent register must precede the subscripted subregister name (4:3).

One final item worth mentioning is the difference between ISP' and CDL bus structures. A bus declaration in CDL such as:

#### Bus, IABUS(0-31), EXDBUS(0-15)

specifies a 32-bit internal address bus and a 16-bit external data bus. However, this declaration differs from the "register" statement only by their keywords. The declaration

## Register, IABUS(0-31), EXDBUS(0-15)

would provide functionally equivalent model components. The capabilities of the "register" and "bus" statements are the same; each provides a storage element capable of being modified by an assignment operation.

ISP' has no special statement to model internal data buses. Therefore, as in the example above, registers would be used in their place. But ISP' does have a declaration to represent an external data bus; the "port" statement. The "port" statement does have special significance, however. Example:

#### port EXDBUS<0:15>;

declares a 16-bit external data bus named EXDBUS. The port EXDBUS provides a means of communicating with external ISP' processes that comprise the system being modeled. Ports are "connected" to the ports of other ISP' components to model a system's communication and control links.

#### Effects Of Language Differences

Having described the basic inherent differences that exist between ISP' and CDL, it now becomes necessary to point out the effects of these differences on the CDL-to-ISP' model transformation process. As mentioned in Chapter II, the foremost objective of the transformation process is to produce an ISP' model that is functionally equivalent to its CDL counterpart. An additional self-imposed constraint was to attempt to create as much one-to-one correspondence between CDL and ISP' statements as possible to make model equivalency more readily apparent and aid in the model development and debugging process.

Similarities in the declaration statements of both CDL and ISP' made transformation of hardware component statements relatively easy and straightforward. However, the transformation of the microstatements was not as direct: the principal reason being the significant differences that exist in the way timing and control information are represented. In this section, differences in the model declaration sections, as well as those major differences in

the representation of timing and control information that had a broad impact on the way in which all instructions were transformed are identified.

Registers. The declaration sections from both the MC68000 CDL model and the resulting ISP' equivalent are presented in Appendix B. The first minor change made during the transformation was that the address and data registers were declared as an array of registers in the ISP' model rather than by individual statements. Both have equivalent results; the ISP' declaration only reduced the number of register statements (CDL has an equivalent capability but was not used). One additional difference is that CDL uses the convention that the most significant bit is determined by the size of its numerical bit designators. In ISP' the most significant bit always occupies the leftmost position regardless of its numerical designator. For example,

> CDL ISP' PC(0-31), PC<0:31>,

in the above declarations the most significant bit of the CDL register declaration would be PC(31), while it would be PC<0> for the ISP' declaration. To compensate for these differing conventions, ISP' registers are declared with its register bounds reversed so that microstatements referencing register bit positions would not have to be changed (i.e., PC<31:0>). In this way, a reference to bit 31 of PC would specify the most significant bit in either language model.

Subregisters. The next major difference occurs in the subregister statements. Since ISP' format statements allow the independent naming of register subfields, the parentheses enclosing subregister subscripts have not been included in its subregister declarations. For example, the CDL declaration

PC(LOW) = PC(0-15),

becomes

$$PCLOW = PC < 15:0 >$$
,

in ISP'.

Buses. As mentioned earlier, the ISP' port is provided to allow communications with other external components of the system being modeled. The CDL external bus declarations (DBUS and ABUS) do not have a special simulation function, but only serve to represent a bus structure. Even though these external buses are declared as ports in the ISP' description, they are unconnected and nonfunctional since there are no external system components. And since there are no ISP' structures representing internal buses, equivalent register statements are used to describe internal buses in the manner of the earlier example (page V-10).

<u>Decoders</u>. Hamby and Guillory used CDL decoder statements to decode the instruction register to provide the control information to trigger the microstatements necessary to execute the instruction (8:VI-8). They are:

Decoders, A (0-3) = IR(14-15), B(0-3) = IR(12-13), C(0-7) = IR(9-11), D(0-7) = IR(6-8), E(0-7) = IR(3-5), F(0-7) = IR(0-2), G(0-15) = IR(8-11),

The Motorola's MOVE.W D1,D2 instruction can be used to demonstrate their use. Since this instruction's binary representation is 001101000000001, the instruction register's portion of the label's control expression becomes

H(0-3) = IR(6-7),

/A(0)\*B(3)\*C(2)\*D(0)\*E(0)\*F(1)\*..../ .

Since decoder structures do not exist in ISP, those above were eliminated from the ISP' model. Instead, the instruction register decoding process was described by an ISP' "case" statement that used the instruction register as the evaluated expression. As an example, the ISP' case statement

#### case IR 0b001101000000001: MOVEWD1D2 0b0100111011010000: JMPA0 esac

would execute the procedure MOVEWD1D2 or JMPA0 depending on the binary value in the instruction register IR. The procedures MOVEWD1D2 and JMPA0 would contain the microstatements necessary to accomplish their respective instructions. This example is the initial instance where the differences in the handling of control information in nonprocedural CDL requires significant changes during the development of its ISP' equivalent.

<u>Clock</u>. ISP' does not support CDL's explicit two-phase clock declaration used in Hamby and Guillory's 68000 model. Because of its clock capability, CDL is best suited for synchronous systems while ISP' is oriented towards asynchronous systems (2:148). Timing signals necessary for processor operation in ISP' are normally provided by an externally-modeled clock forming part of a system. The absence of this independent, specialized timing component was also a major cause of model differences.

There were basically two approaches that could be used to circumvent this difference. First, an external clock could be modeled that provided alternating phase-one and phase-two signals. These signals would be received via ports to support the activation of "wait" statements. As an example, listed below are several execution statements extracted from the CDL model of one of the 68000's MOVE instructions.

Each label's control expression contains three elements of timing and control. "Ctrl" represents the decoded contents of the instruction register used to select the execution

statements for a particular instruction. The timing and sequencing of the execution statements for that instruction are governed by the "K" and "P" elements. The K elements are timing signals from a clock-cycle counter. These signals are created by declaring a 8 X 256 decoder per the earlier CDL example:

#### Decoder, K(0-256) = T(0-7).

The binary value of T will translate into one and only one of K's 256 output signals that can be used to count clock cycles and sequence through CDL execution statements.

Decrementing the value of the control register T via the "CountdnT" operator also changes the corresponding state of K's control signal output. In this way, one is able to recover a clock cycle. The above CDL routine represents a loop that allows the processor to wait for DTACKN to become low. CDL's ability to segregate control and data, while at the same time enabling control to be modified via its microoperations, is a major stumbling block in the efficient transformation from CDL to ISP'. With ISP', the control provided by K must be handled by conditional statements that become part of the ISP' microstatements themselves. Efficient transformation is also exacerbated by the fact that alternating phase-one and phase-two timing signals are automatically provided by an external clock to provide an additional level of sequencing within each clock cycle. Assuming an externally modified two-phase clock, the ISP'

model that follows is equivalent to the previous CDL routine. case ctrl decoded instruction 1: 1st instruction's routine decoded instruction 2: 2nd instruction's routine decoded instruction n: last instruction's routine esac; instruction n's routine := while K<2> ( wait(phil:lead); if not DTACKN T = T + 1;delay(1) ); while K<2> do ( wait(phi2:lead); T = T + 1;delay(1); while K<3> wait(phil:lead); if DTACKN T = T - 1;delay(1) ) until not DTACKN; while K<3> wait(phi2:lead); EXDBUF = DBUS;T = T + 1;delay(1) );

V-17

<u>Clock and Clock-Cycle Counter Representation</u>. From the above CDL and ISP' examples, a couple of facts emanating from the differences between procedural ISP' and nonprocedural CDL become clear:

 the models become dissimilar in appearance, and the equivalency of the models becomes obscured by differences in the method in which timing and control signals are represented.

2) the flow of execution of the ISP' model is more difficult to follow because of the infusion of the conditional constructs (i.e., while, wait, do...until) into the microstatements in order to represent the timing and control.

These elements have an adverse impact on the process of establishing model equivalency that is essential to validation of the models developed by Hamby and Guillory. Such diversity would also hamper attempts to locate causes of differences between the simulation results and the documented logic analyzer output.

One fact not made clear by the above examples is that the ISP' simulation will be much more complex because of the additional modeling of the clock-cycle counter and two-phase clock components. Modeling these devices, and the synchronization that must be achieved between the resulting system components, significantly increases the complexity of the simulation's construction.

An alternate ISP' representation of the above sequence

that includes an internal two-phase clock and control register is depicted below.

T = 2; next phil = hi; phi2 = 10;while DTACKN eql hi next; phil = 10;phi2 = hi; next = 3; next phil = hi; phi2 = lo; next T = 2): next; T = 3; next phil = lo;phi2 = hi;EXDBUF = DBUS; next

One first notes that the clock-cycle counter K is not present. Although it better depicts the actual operations taking place within the microprocessor, it has been removed because it is nonessential to the model's accuracy. The condition K<2> is equivalent to the condition T eql 2. Thus the elimination of decoder K resulted in a simpler model by removing an unnecessary level of indirection.

The wait and while statements associated with the control signals have also been eliminated. This was achieved by modeling an internal two-phase clock and clock-cycle counter. The processor no longer relies on external components to provide these signals. It provides them itself by including statements that represent the required clock states at appropriate points in an instruction's microstatement sequence. Thus, rather testing for K<3> and then waiting for phil, it directly sets T = 3 and phil = hi and then executes the microstatements associated with phase one of clock cycle three.

By internally modeling these components, the speed of the simulation increases because the process representing the microprocessor is not idled by the delay and wait statements. These statements transfer simulation execution to the other system components by placing the 68000 model in the "wait" state and then "running" the process representing either the external clock or clock-cycle counter as appropriate (6:3). This continual process-swapping severely slows the simulation. Also, because the frequency of the 68000's host clock was not reflected in the original CDL model, the delay statements become unnecessary. The models are functionally equivalent, only the later does not reflect independent timing and control signals. The ISP' example also assumes a correctly functioning clock and control register, which is acceptable when not modeling hardware failure.

This representation brings the CDL and ISP' models more in-line with one another. In the ISP' model, separate timing and control signal statements now lead their corresponding microinstructions. This representation makes

equivalency easier to establish and greatly simplifies development of the simulation system. An external clock and clock-cycle counter no longer has to be modeled and interfaced with the MC68000. For these reasons, the second ISP' modeling approach was selected. Rather than strive for the segregation of control and timing information from the microstatements as is done in the real world and handled so nicely by CDL, these elements are internally modeled to enhance model semblance and reduce simulation complexity, while at the same time preserving the functional accuracy of the MC68000 model.

<u>Switch</u>. Because ISP' does not support a "switch" statement, it was modeled with a single bit register named "SWITCH" that is either set to high to simulate system power on, or low to simulate power off.

## Model Changes

Now, modifications made to the model that are not the result of the inherent differences that exist between CDL and ISP' are presented. These changes or additions were made to enable a functioning simulation, initialize the model's storage components, or to modify component declarations. Changes peculiar to a particular instruction are discussed in the next chapter which analyzes the results of the model's simulation.

<u>Memory Responses</u>. Upon reexamining the earlier CDL example,

one notices that during the simulation the value of DTACKN must be low for these execution statements to complete, else the routine would be caught in an infinite loop executing the second and third CDL execution statements. Because Hamby and Guillory did not intend to externally model the ECB's memory, the activities associated with that memory's processing of the data and control signals that exist between it and the 68000 (i.e., R\_W, ASN, LDSN, UDSN, ABUS, DBUS) do not appear in their CDL model of the 68000. However, in order to produce a functioning simulation, the memory's responses to actions initiated by the 68000 must be represented. Again, one becomes faced with the decision to either externally model the ECB's memory to represent the real-word environment, or as was done with the timing and control signals, place the memory responses in-line with the 68000's microinstructions at points that coincide with the results observed by Hamby and Guillory on the logic analyzer and documented in Chapter VI of their thesis.

For example, according to the logic analyzer output for the MOVE.W Dl,D2 instruction, the ECB's memory placed the instruction requested during its prefetch cycle on the data bus during phase one of clock cycle three. It also took DTACKN low at that time indicating that valid data was on

v-22

the bus. Although the CDL model does not reflect the memory's responses, they must be modeled somewhere to provide a working simulation. To simplify the construction of the simulation, memory responses were inserted in-line with the code in accordance with the logic analyzer results. This does not detract from the model's accuracy. Accordingly, the ISP' model becomes

(•

T = 2; next phil = hi; phi2 = lo;while DTACKN eql hi next; phil = lo;phi2 = hi; next T = 3; next phil = hi; phi2 = 10;DBUS < 15:8 > = M[ABUS];DBUS < 7:0 > = M[ABUS + 1];DTACKN = lo; next T = 2); next; T = 3; next phil = lo;phi2 = hi;EXDBUF = DBUS; next

Now the memory location's contents specified by the address bus (ABUS) is placed on the data bus (DBUS) and DTACKN is taken low. This will enable the MOVE instruction to prefetch the next instruction and proceed with its execution. Memory reads or writes requiring wait states

were modeled by including a "wait-cycle" counter in the loop to accomplish the data transfer on the correct clock cycle.

EXABUF Size. Hamby and Guillory declared a 16-bit external address buffer with the "EXABUF(0-15)" statement. Because the MC68000 has a 23-bit address bus, the buffer size was enlarged to 23 bits with the following ISP' port declaration:

## EXABUF<23:1>, .

ABUS Utilization. In none of the instruction sequences did Hamby and Guillory explicitly move the contents of the external address buffer (EXABUF) to the address bus (ABUS). In practice, when the data is loaded into EXABUF, its contents would automatically appear on the address bus (if ABUS had been enabled). Subsequently, there is an implied transfer of an address to the address bus when EXABUF is loaded. However, since the CDL bus declaration does not provide any physical relationship between any of its declared buses and system registers, such a transfer must be accomplished explicitly by the statement "ABUS = EXABUF". This additional address transfer allowed a more accurate representation of the memory addressing mechanism. Now, rather than identifying a memory location with the ISP' statement

#### DBUS < 15:8 > = M[EXABUF];

the statement

#### DBUS < 15:8 > = M[ABUS];

can be used and more accurately describes the memory addressing process.

<u>Memory Declaration</u>. Hamby and Guillory also specified an eight-megaword memory with the declaration "Memory M() = M(0-8388607,0-15)" (8:VI-8). This corresponds to the MC68000's maximum physical addressing range. However, to more accurately represent the ECB environment, the memory size was reduced to 32 kbytes with the declaration "memory M[0:32767]<7:0>" without affecting the model's functional accuracy.

High Impedance Representation. The entire data and address buses were placed in a high state to simulate their high impedance states whenever not being used by the 68000 or its memory. Although not modeled by Hamby and Guillory, this matches the logic analyzer's output. The ISP' statements

> DBUS = 0xffff; ABUS = 0xfffff;

were added to the ISP' microstatements as needed to place the data or address bus in a high impedance state whenever appropriate (i.e., DBENABLE, ABENABLE = 10). Likewise, the ECB's empty memory locations are also in a high state. Therefore, simulated memory locations immediately following the JMP (A0) instruction of all test routines are initialized to the high state to meet the observed results

(unused memory locations are set to a low state by N.mPc).

<u>Power-On Sequence</u>. A power-on and initialization routine (power\_on\_initialize) was added to the model to:

 accomplish the 68000's power-on sequence as described by Hamby and Guillory (8:VI-9),

 initialize appropriate registers prior to each test routine as specified by Hamby and Guillory in Appendix A of their thesis,

 initialize the data and address buses to the high impedance state,

4) initialize the 68000's active low memory control signals to the high state, and

5) initialize memory to the high state.

#### Additional Simulation Components

Not relevant to the MC68000 microprocessor model's accuracy, but important to the development of the simulation package, is the development of Metamicro and Linking/Loader programs. In addition to the model of the 68000 processor, a description of the 68000's instruction set had to be developed to transform the MC68000 assembly language test routines into executable code for the processor model. A loader is needed to initialize the 68000's internal memory with this code. Because N.mPc's library included programs that could be modified to accomplish these functions, they were used rather than undertake an extensive and redundant development effort. The Metamicro and Linking/Loader descriptions used were developed by Samir Shah while a

graduate student at Case Western Reserve University and are included in appendices D and E respectively with the modifications described below.

51-

Program Loader. One of the changes made to Shah's Linking/Loader description was an alteration of the "space " statement. To reflect the fact that all instruction test routines were loaded into the ECB's 32-kbyte memory beginning at address location 1000 hex, the space declaration for them was changed from "space<0:4095>\$" to "space <4096:32767>\$". Because the exception processing routines required use of lower memory to support the vector table and system stack area, their Linking/Loader description's space declaration became "space <0:32767>\$". Program location was then accomplished within Metamicro. To support the use of labels within a program, the "mode" declaration was enhanced with the following statements:

> case Opcode eql 6: Il = address - . - 2 \$ break\$ esac.

And finally, the assignment "IO = 0x4d \$" within the "transfer" statement was changed to "IO = 0x4e \$" to accurately represent the JMP instruction's format.

MC68000 Assembler. Hamby and Guillory initialized bit 13 of the status register (mode selection bit) to zero with the priviledged instruction "AND.W #\$DFFF,SR" to indicate the user mode. Because Shah did not model priviledged

instructions in his Metamicro description of the 68000, this instruction was not included in the early simulation test routines. Instead bit 13 of the status register was set to zero in the power-on and initialization routine without model degradation because the 68000's output signals were only examined when the instruction of interest was executing and not during the execution of the AND.W instruction. Since this instruction was omitted from the test routines, address register A[0] was loaded with 1000 hex instead of 1004 hex to enable the JMP (A0) to function correctly. Once Metamicro was mastered, Shah's Metamicro description of the 68000's instruction set was modified so it could assemble the "AND.W #\$1000,SR" instruction. As a result, some later routines include this instruction. In those that do, the PC and A[0] are initialized to 1004 hex in the instruction's ISP' description. These routines also use the later version of the modified Linking/Loader program.

From the test routines in Appendix D, one notes that basic differences exist between them and the standard MC68000 assembly code. They are:

 the operand's size specification is segregated from the instruction mnemonic,

2) prefixes are incuded to specify each operand's addressing mode (special symbols such as "#" and "\$" are not recognized by Metamicro),

3) all operands are separated by commas, and

4) parenthesis surround an instruction's operands.





MICROCOPY RESOLUTION TEST CHART

These changes are mandated by Metamicro macro-oriented structure.

•

#### VI. <u>Simulation Analysis</u>

### Introduction

An ISP' model was constructed and then simulated for each CDL instruction or exception model developed by Hamby and Guillory. In addition to the MOVE (16 variations), JMP, ADD, BEQ, and BTST instructions, they also included the Illegal Instruction and Address Error exceptions. The results of each simulation were carefully compared with the logic analyzer data tabulated by Hamby and Guillory in Chapter VI of their thesis. Differences were analyzed for their causes and they in turn were evaluated for their severity. A difference's impact on the validity of this approach to microprocessor modeling could be gauged in terms of the answer to the following question: could the noted difference be explained?

Regardless of their numbers and type, abnormalities whose causes could be isolated, could also be eliminated by correcting either the model or logic analyzer output data as appropriate. Although it is possible to model unexplained (but predictable) behavior, many differences (especially those that are repetitive) that cannot be satisfactorily interpreted would strongly suggest that this particular approach is not practical when a highly accurate model is the objective.

Because there were no differences that were unexplanable, the results of the simulations' analyses

indicate that the models developed by Hamby and Guillory accurately describe the MC68000's behavior when processing the above instructions and exceptions. Differences that were considered major (primarily because of their repetitiveness), centered around the state of the address and data buses (ABUS and DBUS) during transitional periods and had little effect on the functional accuracy of the model. The consistent accuracy of Hamby and Guillory's models strongly supports this approach as a microprocessor modeling technique.

In this chapter the overall results of the analyses are first presented. Here the results of the individual model analyses have been consolidated and evaluated to identify the major or consistent differences that reflect on the viability of this modeling approach. These differences are identified, interpreted, and then individually and collectively assessed for their impact on this approach. This discussion is followed by sections that detail the simulation results for the individually modeled instructions or exceptions from which the assessment of this approach was formed.

## Analysis Results

Based on the analysis of the simulation results, there is little doubt that microprocessors can be accurately modeled through signal analysis with minimal supporting technical data. Except on those rare occasions when microstatements were incorrect or omitted, the simulation

results deviated little from the analyzer output, particularly with the 68000's memory control signals (i.e., DTACKN, AS, UDS, LDS, and R/W). However, as mentioned there were some deviations from the data and address bus states reported by the logic analyzer whenever these buses would transition to the high impedance state at the beginning of a read or write cycle. The differences were consistent and predictable throughout the instruction models and result from the 68000's inability to complete its activities well within the logic analyzer's sampling intervals. These bus differences do not have a major impact on the accuracy of the models because they are of short duration (half clock cycle) and they occur at points where the ABUS or DBUS are not being monitored by either the processor or its memory.

The problem of accurately modeling the high impedance state is really inconsequential to the functional correctness of the model; however, a major section is devoted to discussing this problem, even at the risk of overstating its significance. With so few global inconsistencies in the models, considerable attention can be given to this anomaly. The accuracy and completeness of the models developed by Hamby and Guillory is a tribute to their hard work and thorough understanding of microprocessor structure and operation.

#### High Impedance State

The differing times in which the 68000 and its supporting memory release the data and address buses during

read and write cycles made their state difficult to accurately model during the transition to a new cycle. The specific problem areas are addressed in detail in the sections that follow.

Data Bus. The available technical data specifies that during a read cycle the memory must remove its data and data transfer acknowledge (DTACK) signal within one clock period of recognizing the 68000's negation of the address strobe (AS) that occurs during phase two of the last read clock cycle (11:38). On the other hand, during a write cycle the technical data (1:4) specifies that the 68000 will release the data bus no earlier than 60 ns from AS negation (no maximum figure is provided). AS is also negated during phase two of a write's last clock cycle. Based on the logic analyzer results, it appears that the ECB's memory releases the data bus much sooner after the completion of a read cycle than the 68000 does when completing a write cycle.

For a read or write cycle, the logic analyzer finds the data bus in the high impedance state during phase one of their initial clock cycle - provided they do not follow another write cycle. Should they happen to follow another write cycle, then the logic analyzer does not see the data bus returned to the high state until phase two of their initial cycle. While the specific point in which the bus is "high-impedanced" cannot be determined for either the read or write cycle, time intervals for each can be estimated using available timing information.

The logic analyzer samples data at the low and high transitions of the system clock in accordance with Figure VI-1. The figure shows that for any clock period, the phase one sample will reflect changes that occur with the clock signal high and phase two will catch state changes that occur during the low clock signal.



Figure VI-1. Logic Analyzer Sampling Points

Performance specifications for the Hewlett Packard 1600A Logic State Analyzer indicate that data must be present at least 20 ns prior to clock transition for it to be captured during the current phase (24:1-1). Figure VI-2(a) presents the maximum time (120 ns) in which the 68000 will place the data bus in the high impedance state upon entering a read or write cycle (1:4). In order for the logic analyzer to capture the high impedance state during phase one, then the bus must be in this state within 95 ns of the beginning of the read or write cycle. It appears that the 68000 disables the bus somewhere between 86 and 110 ns after the start of the first clock cycle. Because the signals have a 10 ns rise/fall time (1:4), the bus will reach the high impedance state in 96 to 120 ns (Figure VI-2(b)). These figures indicate that the logic analyzer

should not show the data bus returning to the high impedance state until phase two of the first clock cycle for both read and write cycles. This is not the case.



Figure VI-2. Data Bus High Impedance Timing (1:5,6)

Since the 68000 does not place the data bus in a high impedance state in sufficient time to be captured by the logic analyzer on phase one of clock cycle zero for either a read or write cycle, then the only explanation for the logic analyzer results is that a previous cycle is sometimes able to return DBUS to high impedance so that it is captured by the logic analyzer during phase one, even though the current cycle fails to do so itself.

During a read cycle it is the memory's responsibility to return the data bus to the high impedance state once the

68000 has received the requested data. As mentioned earlier, it has up to a full clock cycle from phase two of the last read clock cycle to do this. The change could take place as late as phase two of the following clock cycle. However, it appears that the ECB memory responds much faster than necessary. Referring to Figure VI-2(c), the ECB memory must disable DBUS no later than 85 ns into the following clock cycle because it is being captured by the logic analyzer during phase one. In the case where the 68000 is responsible for returning the bus to the high impedance state (end of a write cycle), it fails to do so in time to compensate for the initial clock cycle's failure. In fact, it is possible that the 68000 relies on the following read or write cycle to accomplish this.

Hamby and Guillory's model specifies that the data bus is disabled during phase one of both the read and write clock cycles and is reflected in the initial simulation results. However, because the 68000 does not accomplish this action in time during a write cycle to be captured by the logic analyzer until the next phase, it appears as though the model is inaccurate. The technical data supports their model even though the timing resolution of the logic analyzer disguises its accuracy.

In terms of accurately modeling any instruction, one must then be aware of the types of cycles and their ordering so that the state of the data bus can be accurately portrayed at any given time. That is, one must know whether
the previous cycle was a read or write so that the correct variation of the current cycle can be determined and modeled to place the data bus in the high impedance state at the correct moment. This adjustment was made during the model transformations once the problem was recognized. It is important to note that even though this was easily accomplished, it is not necessary in terms of a correctly functioning model. The state of the data bus is of no consequence during the initial phase of a read or write clock cycle because no device is monitoring it at that point. During either a read or write cycle, the 68000 can receive or issue valid data no sooner than a full clock cycle later.

Address Bus. A similar situation exists whenever the address bus (ABUS) is transitioning to the high impedance state. As with the data bus, the 68000 places ABUS in the high impedance state no later than 120 ns from the beginning of a read or write cycle. The logic analyzer results indicate that ABUS is in an indeterminate state during phase one of the initial period in a read or write cycle. In some instances the address bus was found in a high impedance state during phase one; however, there were just as many other cases where it contained the address from the previous read or write cycle, or it was in a state somewhere between the two (previous address and high impedance). This strongly indicates that the logic analyzer was sampling the data at approximately the same instant in which the 68000



was returning the bus to the high impedance state.

Figure VI-3. High Impedance On Address Bus

Looking at Figure VI-3, it appears that this is occurring at approximately 85 ns into the initial clock cycle. If the 68000 disables the bus at 85 ns into its cycle, then with a 10 ns rise/fall time the bus will return to high impedance at 95 ns (the cutoff time for the logic analyzer to capture it). Timing is critical and a delay of as little as a single nanosecond will mean the difference between the logic analyzer catching the address bus in the high impedance state during phase one or not.

As with data bus modeling, even though the simulation results will not always agree with the results of the logic analyzer (the simulation will always reach the high impedance state), this indeterminate state lasts but a half clock cycle and occurs at a point where the bus is of no consequence to system devices. For both read and write cycles, the 68000 does not take AS low to indicate a valid address until a full clock cycle later.

# Individual Instruction Simulation Results

The simulation results for each modeled instruction will be individually compared and contrasted with logic analyzer's reflection of the 68000's actual operation. Each section contains a brief description of the instruction or exception, lists the simulation data, and then explains their differences and corrections. The individual ISP' models of each instruction or exception sequence, the files that controlled the simulations, and the simulation output from which the tabulated signal data was prepared appear in Appendices C, G, and H respectively. Appendix F lists the instruction test routines that were executed on the models during the simulations. The CDL models and logic analyzer data from which the comparisons were made are contained in Appendices I and J respectively. All addresses and data values used in the discussion are given in hexadecimal.

Excluding wait cycles, read cycles require four clock cycles to execute. The ECB memory required one and a half clock cycles to provide the requested data causing the 68000 to run a full wait cycle during its reads. Subsequently, all read cycles require five clock cycles to complete. During writes to memory, the 68000 must also wait one and a half cycles before the ECB memory formally acknowledges data receipt. With the wait cycle included, a normal four-cycle write will also require five clock cycles to execute. As a matter of convention, all instruction cycle lengths given in this chapter will include wait cycles. When running the simulations, 16 of the MC68000's 64 pins were monitored to provide sufficient information to identify the internal processing taking place. These signals along with the columns in which their states appear in the simulation data are identified below.

| Column | Signal                            |
|--------|-----------------------------------|
| 0      | FC0 (Function Code 0 output)      |
| 1      | FC1 (Function Code 1 output)      |
| 2      | FC2 (Function Code 2 output)      |
| 3      | DTACK' (Data Transfer Acknowledge |
| 4      | R/W' (Read/Write signal)          |
| 5      | LDS' (Lower Data Strobe)          |
| 6      | UDS' (Upper Data Strobe)          |
| 7      | AS' (Address Strobe)              |
| 8      | D0 (Data line 0)                  |
| 9      | Dl (Data line 1)                  |
| 10     | D2 (Data line 2)                  |
| 11     | D3 (Data line 3)                  |
| 12     | D4 (Data line 4)                  |
| 13     | D5 (Data line 5)                  |
| 14     | D6 (Data line 6)                  |
| 15     | D7 (Data line 7)                  |

For several of the instructions, it was necessary to monitor the address bus as well. Whenever this was done, only the first four data lines (DO-D3) were monitored. D4-D7 were replaced with Al-A4 and the results entered in columns 12-15 of the simulation data. The only exception to this convention occurs while simulating the Illegal Instruction exception sequence. In this lone case, address lines Al-A4 were monitored in addition to the eight data lines D0-D7 to provide greater data range when also observing addresses. For this instruction, Al-A4 appear in columns 16-19.

## MOVE.W D1.D2

The MOVE.W D1,D2 instruction was the first to be modeled and simulated. This single-word instruction uses the data register direct addressing mode to move the contents of data register D1 to data register D2. Because this instruction is executed in a single read cycle (prefetch), it required only five clock cycles to execute. Only the function code, peripheral control, and data lines were monitored during the simulation. The simulation results were:

|              |              | 15-12<br>DDDD<br>7654 | 11-8<br>DDDD<br>3210 | 74<br>AULR<br>SDD/<br>SSW | 30<br>DFFF<br>TCCC<br>A210<br>C<br>K | (columns)<br>(signals)                                                                                                                                                                                                                                    |
|--------------|--------------|-----------------------|----------------------|---------------------------|--------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| K(0)<br>K(0) | P(1)<br>P(2) | 1111<br>1111          | 1111<br>1111         | 1111<br>1111              | 1010<br>1010                         | <pre>\$Data bus (8-15) in high<br/>\$impedance state, R/W'<br/>\$signal (4) indicates a<br/>\$read cycle, function codes<br/>\$(0-2) identify user<br/>\$program mode</pre>                                                                               |
| K(1)<br>K(1) | P(1)<br>P(2) | 1111<br>1111          | 1111<br>1111         | 0001<br>0001              | 1010<br>1010                         | \$AS' (7) indicates a<br>\$valid address on address<br>\$bus; UDS', LDS' (5-6) for<br>\$a word size operation                                                                                                                                             |
| K(2)<br>K(2) | P(1)<br>P(2) | 1111<br>1111          | 1111<br>1111         | 0001<br>0001              | 1010<br>1010                         | <pre>\$DTACK' (3) not asserted<br/>\$by peripheral device (data<br/>\$not ready) so processor<br/>\$runs a wait cycle.</pre>                                                                                                                              |
| K(3)<br>K(3) | P(1)<br>P(2) | 0000                  | 0001<br>0001         | 0001<br>0001              | 0010<br>0010                         | <pre>\$Data applied to data bus<br/>\$(8-15), DTACK' (3) asserted<br/>\$indicating to processor<br/>\$that data is on the bus.<br/>\$The data on the bus is<br/>\$code for MOVE.W D1,D2<br/>\$instruction indicating<br/>\$that this is a prefetch.</pre> |
| K(4)<br>K(4) | P(1)<br>P(2) | 0000<br>0000          | 0001<br>0001         | 0001<br>1111              | 0010<br>1010                         | \$AS', UDS', LDS' (5-7)                                                                                                                                                                                                                                   |

Schange to notify Speripheral device that Stransfer is complete.

Because the simulation results echoed the results observed through the logic analyzer during the actual operation of the MC68000, Hamby and Guillory appeared to have little difficulty modeling this version of the MOVE instruction. There were, however, two changes made to their model during its transformation to ISP'. At phase two of clock cycles zero and three, decoder K was directly incremented with the CDL statement "K <- CountupK". Incrementing K directly would not achieve the desired results. The decoder's successive output line can be activated by incrementing its input clock cycle register, T, with the CDL statement "T <- CountupT" (T = T + 1 in ISP').

## MOVE.W D1, (A1)

The MOVE.W Dl,(Al) instruction uses both the data register direct and address register indirect addressing modes to move the contents of data register Dl into the memory locations identified by the contents of address register Al. This version of the MOVE instruction consisted of single read and write cycles requiring 10 clock cycles to execute. During the simulation, no address lines were monitored and the results did not differ from the logic analyzer data. They were:

15-12 11-8 7--4 3--0 (columns) DDDD DDDD AULR DFFF (signals) 7654 3210 SDD/ TCCC SSW A210 С K K(0) P(1)1111 1111 1111 1010 \$Data bus (8-15) in high K(0) P(2) 1111 1111 1111 1010 \$impedance state, R/W' \$signal (4) indicates a \$read cycle, function codes \$(0-2) identify user \$program mode. 1111 1111 0001 1010 \$AS' (7) indicates a K(1) P(1) K(1) P(2) 1111 1111 0001 1010 \$valid address on address \$bus; UDS', LDS' (5-6) for \$a word size operation. K(2) P(1)1111 1111 0001 1010 \$DTACK' (3) not asserted K(2) P(2)1111 1111 0001 1010 \$by peripheral device (data \$not ready) so processor \$runs a wait cycle. K(3) P(1) 1000 0001 0001 0010 \$Data applied to data bus 1000 0001 0001 0010 \$(8-15), DTACK' (3) asserted K(3) P(2) Sindicating to processor \$that data is on the bus. \$The data on the bus is \$code for MOVE.W Dl,(Al) \$instruction indicating \$that this is a prefetch. 1000 0001 0001 0010 K(4) P(1) K(4) P(2)1000 0001 1111 1010 \$AS', UDS', LDS' (5-7) \$change to notify \$peripheral device that \$transfer is complete. K(5) P(1) 1111 1111 1111 1010 \$Begin write cycle. \$Data bus (8-15) in \$high impedance state. K(5) P(2)1111 1111 1111 1001 \$Function code (0-2) \$is user data mode. K(6) P(1) 1111 1111 0110 1001 \$AS' (7) asserted to \$indicate valid address on \$ bus, R/W' (4) changes \$to write cycle. 0101 0101 0110 1001 \$Data put on data bus K(6) P(2) \$(8-15). Data is 55 hex \$which is same as data \$stored in Dl. 0101 0101 0000 1001 \$UDS', LDS' (5-6) identify 0101 0101 0000 1001 \$word size, DTACK' (3) not K(7) P(1)K(7) P(2) \$asserted by peripheral \$so wait cycle run by \$processor. 0101 0101 0000 1001 \$DTACK' (3) not asserted K(8) P(1)

# MOVELL DI, AL

( •

The single-word instruction MOVE.L Dl,Al uses both the data register and address register direct addressing modes to move the 32-bit contents of data register Dl to address register Al. This instruction consists of a single read cycle that required five clock cycles to execute. No address lines were monitored. The results were:

|                |              | 15-12<br>DDDD<br>7654 | 11-8<br>DDDD<br>3210 | 74<br>AULR<br>SDD/<br>SSW | 30<br>DFFF<br>TCCC<br>A210<br>C<br>K | (columns)<br>(signals)                                                                                                                                                       |
|----------------|--------------|-----------------------|----------------------|---------------------------|--------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| K (0)<br>K (0) | P(1)<br>P(2) | 1111<br>1111          | 1111<br>1111         | 1111<br>1111              | 1010<br>1010                         | <pre>\$Data bus (8-15) in high<br/>\$impedance state, R/W'<br/>\$signal (4) indicates a<br/>\$read cycle, function codes<br/>\$(0-2) identify user<br/>\$program mode.</pre> |
| K(l)           | P(1)         | 1111                  | 1111                 | 0001                      | 1010                                 | \$AS' (7) indicates a                                                                                                                                                        |
| K(1)           | P(2)         | 1111                  | 1111                 | 0001                      | 1010                                 | <pre>\$valid address on address \$bus; UDS', LDS' (5-6) for \$a word size operation.</pre>                                                                                   |
| K(2)           | P(1)         | 1111                  | 1111                 | 0001                      | 1010                                 | \$DTACK' (3) not asserted                                                                                                                                                    |
| K(2)           | P(2)         | 1111                  | 1111                 | 0001                      | 1010                                 | Sby peripheral device (data<br>Snot ready) so processor<br>Sruns a wait cycle.                                                                                               |
| K(3)           | P(1)         | 0100                  | 0001                 | 0001                      | 0010                                 | \$Data applied to data bus                                                                                                                                                   |
| K (3)          | P(2)         | 0100                  | 0001                 | 0001                      | 0010                                 | <pre>\$(8-15), DTACK' (3) asserted<br/>\$indicating to processor<br/>\$that data is on the bus.<br/>\$The data on the bus is<br/>\$code for MOVE.L D1.A1</pre>               |

\$instruction indicating
\$that this is a prefetch.
K(4) P(1) 0100 0001 0001 0010
K(4) P(2) 0100 0001 1111 1010 \$AS', UDS', LDS' (5-7)
\$change to notify
\$peripheral device that
\$transfer is complete.

The only difference between the simulation results and the data from the logic analyzer occurs at phase two of clock cycle two. The logic analyzer shows the data bus changed from its high impedance state of the previous cycle to "loll llll" on its way to the value data state "0100 0001" at phase one of clock cycle three. Because this occurs at a point in the read cycle where the memory is placing data onto the bus, it appears that the logic analyzer has caught the data bus in transition to its valid data state. The simulation differs by maintaining the high impedance state during this phase.

#### $MOVE_W Dl_(Al) +$

MOVE.W Dl,(Al) + is a single word instruction that uses the data register direct and postincrement register indirect addressing modes to move the contents of data register Dl to the memory location pointed to by the contents of address register Al. After Al is used to address the memory location, it is incremented by two. It is comprised of single read and write cycles that require ten clock periods to execute.

Instead of monitoring eight data lines, only the first four were examined during the execution of this instruction. Hamby and Guillory replaced data lines D4-D7

with the four least significant address lines (Al-A4) to view the postincrement process. The reader should be aware that these lines do not include bit zero of the program counter; they only represent PC<4:1>. PC<0> does not appear on the address bus. Rather, it is internally encoded along with the instruction's operand length to activate the upper and lower data strobes (UDS and LDS) (11:38).

The 68000 uses PC<0> to determine which byte to read or write and then activates either UDS, LDS, or both depending on the operand size. Whenever the instruction specifies a byte operand, UDS is activated if PC<0> is zero. If it is a one, then LDS is activated. For word size operands, both UDS and LDS are activated and PC<0> must be zero to avoid an address error exception. Therefore, for the word or longword size instructions that dominate the models, an extra zero should be appended to the address bus data to arrive at the correct memory address accessed by the processor. In terms of an accurate representation of this process in the instruction models, the sequence of CDL microstatements that transfer the program counter to the address bus (i.e., IABUS <- PC, EXABUF <- IABUS, and ABUS <-EXABUF) should be changed at both of the first two stages to support this fact (i.e., IABUS<31:1> <- PC<31:1> and EXABUF <- IABUS<31:1>). The simulation results were:

15-12 11-8 7--4 3--0 (columns) AAAA DDDD AULR DFFF (signals) 4321 3210 SDD/ TCCC SSW A210 С Κ K(0) P(1) 1111 1111 1111 1010 \$Begin read cycle. 0011 1111 1111 1010 \$Address lines (12-15) K(0) P(2) \$are 1006, location of K(1) P(1)0011 1111 0001 1010 \$instruction being K(1) P(2)0011 1111 0001 1010 Sprefetched K(2) P(1) 0011 1111 0001 1010 K(2) P(2) 0011 1111 0001 1010 0011 0001 0001 0010 \$Data applied to data bus K(3) P(1) K(3) P(2) 0011 0001 0001 0010 \$(8-11). Data is code \$for MOVE.W D1,(A1)+. K(4) P(1)0011 0001 0001 0010 K(4) P(2) 0011 0001 1111 1010 \$End read cycle K(5) P(1) 1111 1111 1111 1010 \$Begin write cycle. K(5) P(2) 0000 1111 1111 1001 \$Address lines (12-15) \$are 2000. K(6) P(1) 0000 1111 0110 1001 0000 0101 0110 1001 \$Data put on data bus K(6) P(2)\$(8-11). Data is .) hex K(7) P(1)0000 0101 0000 1001 \$data being moved. K(7) P(2) 0000 0101 0000 1001 0000 0101 0000 1001 K(8) P(1) K(7) P(2) 0000 0101 0000 1001 K(8) P(1) 0000 0101 0000 0001 0000 0101 0000 0001 K(8) P(2) K(9) P(1) 0000 0101 0000 0001 K(9) P(2) 0000 0101 1110 1001 \$End write cycle.

In their CDL model, Hamby and Guillory neglected to increment the program counter or place the contents of the prefetch register into the instruction register during phase two of clock cycle nine. These microstatements were added to the ISP' version. The only difference that occurred between the simulation and the logic analyzer data is the data that appears on the address bus at phase one of clock cycle zero. The simulation reflects the high impedance state while the logic analyzer depicts a partial return to the high impedance state from the address that last appeared on the bus (1004 - the address of the current instruction). The reasons for this difference have been explained and will not be further elaborated upon here.

#### MOVE W D1.04(A1)

MOVE.W D1,04(A1) is a two-word instruction that uses the data register direct and register indirect with offset addressing modes to move the contents of data register D1 to the memory location pointed to by the sum of both address register A1 and the value of the instruction's extention word. The instruction consisted of two read cycles (displacement fetch and instruction prefetch) and one write cycle (move data). It required 15 clock cycles to execute. The four least significant address and data lines were monitored during the simulation. The results were:

15-12 11-8 7--4 3--0 (columns) AAAA DDDD AULR DFFF (signals) 4321 3210 SDD/ TCCC SSW A210 Κ 1111 1111 1111 1010 \$Begin read cycle. K(0) P(1) K(0) P(2) 0011 1111 1111 1010 \$Address lines (12-15) Sare 1006, location of 0011 1111 0001 1010 \$instruction being K(1) P(1) 0011 1111 0001 1010 \$prefetched K(1) P(2) 0011 1111 0001 1010 K(2) P(1) K(2) P(2) 0011 1111 0001 1010

K(3) P(1) K(3) P(2) 0011 0100 0001 0010 \$Data applied to data bus 0011 0100 0001 0010 \$(8-11). Data is 04, Sthe displacement. 0011 0100 0001 0010 K(4) P(1)0011 0100 1111 1010 \$End read cycle. K(4) P(2)K(5) P(1) 1111 1111 1111 1010 \$Begin read cycle. 0100 1111 1111 1010 \$Address lines (12-15) K(5) P(2) Sare 1008, location of K(6) P(1)0100 1111 0001 1010 \$instruction being K(6) P(2) 0100 1111 0001 1010 \$prefetched. K(7) P(1)0100 1111 0001 1010 K(7) P(2) 0100 1111 0001 1010 K(8) P(1) 0100 0001 0001 0010 \$Data applied to data bus K(8) P(2) 0100 0001 0001 0010 \$(8-11). Data is code \$for MOVE.W D1,08(A1). K(9) P(1) 0100 0001 0001 0010 K(9) P(2) 0100 0001 1111 1010 \$End read cycle. K(10) P(1) 1111 1111 1010 \$Begin write cycle. K(10) P(2) 0010 1111 1111 1001 \$Address lines (12-15) Sare 2004. 0010 1111 0110 1001 K(11) P(1) K(11) P(2) 0010 0101 0110 1001 \$Data put on data bus \$(8-11). Data is 5 hex, K(12) P(1) 0010 0101 0000 1001 \$data being moved. K(12) P(2) 0010 0101 0000 1001 K(13) P(1) 0010 0101 0000 1001 K(12) P(2)0010 0101 0000 1001 K(13) P(1) 0010 0101 0000 0001 0010 0101 0000 0001 K(13) P(2) K(14) P(1) 0010 0101 0000 0001 K(14) P(2) 0010 0101 1110 1001 \$End write cycle.

The only difference between the simulation and the logic analyzer results occured on the address bus. At phase one of clock cycles zero and ten the logic analyzer catches the bus transitioning to the high impedance state whereas the simulation fully captures high impedance. This difference has been discussed earlier.

Also, for one and a half clock cycles beginning at

phase one of clock cycle 13, the logic analyzer data indicates that the address bus (A4-A1) is in state "0011" whereas on the previous cycle (phase two of clock cycle 12) it held the address of the memory location to which the data from D1 would be moved (2004). This address manifested itself as "0010" on A4-A1 (add a zero to catch PC<0>). A change to "0011" would indicate that the address was incremented to 2006 in the midst of a write cycle and then again returned to 2004 one and a half clock cycles later. Because this is abnormal behavior for the address bus during a write cycle, and it could not be duplicated, it appears to be a typing mistake.

#### MOVE W D1,04(A1,D7)

. . .

MOVE.W Dl,04(Al,D7) is also a two-word instruction that uses the data register direct and indexed register indirect with offset addressing modes to move the contents of data register Dl to the memory location determined by the sum of the index register (D7), the displacement (4), and the value of address register Al. It required 17 clock cycles to execute its two read and one write cycles. The same signals were monitored as with the previous instruction. The simulation results were:

> 15-12 11-8 7--4 3--0 (columns) AAAA DDDD AULR DFFF (signals) 4321 3210 SDD/ TCCC SSW A210 C K

1111 1111 1111 1010 \$Begin read cycle.
0011 1111 1111 1010 \$Address lines (12-15) K(0) P(1)K(0) P(2) \$are 1006, location of K(1) P(1)0011 1111 0001 1010 \$instruction being 0011 1111 0001 1010 \$prefetched K(1) P(2)K(2) P(1) 0011 1111 0001 1010 K(2) P(2) 0011 1111 0001 1010 0011 0100 0001 0010 \$Data applied to data bus K(3) P(1) 0011 0100 0001 0010 \$(8-11). Data is 04, K(3) P(2) \$the displacement. 0011 0100 0001 0010 K(4) P(1)0011 0100 1111 1010 \$End read cycle. K(4) P(2)1111 1111 1111 1010 \$Address and data K(5) P(1)1111 1111 1111 1010 \$buses (8-15) go high. K(5) P(2) K(6) P(1) 1111 1111 1111 1010 1111 1111 1111 1010 K(6) P(2) 1111 1111 1111 1010 \$Begin read cycle. K(7) P(1)K(7) P(2)0100 1111 1111 1010 \$Address lines (12-15) \$are 1008, location of K(8) P(1) 0100 1111 0001 1010 \$instruction being K(8) P(2) 0100 1111 0001 1010 \$prefetched. 0100 1111 0001 1010 K(9) P(1)0100 1111 0001 1010 K(9) P(2)K(10) P(1)0100 0001 0001 0010 \$Data applied to data bus K(10) P(2)0100 0001 0001 0010 \$(8-11). Data is code \$for MOVE.W D1,08(A1,D7). K(11) P(1)0100 0001 0001 0010 0100 0001 1111 1010 \$End read cycle. K(11) P(2)1111 1111 1111 1010 \$Begin write cycle. K(12) P(1) 0101 1111 1111 1001 \$Address lines (12-15) K(12) P(2) \$are 200A. K(13) P(1) 0101 1111 0110 1001 0101 0101 0110 1001 \$Data put on data bus K(13) P(2) \$(8-11). Data is 5 hex, K(14) P(1)0101 0101 0000 1001 \$data being moved. 0101 0101 0000 1001 K(14) P(2) K(15) P(1) 0101 0101 0000 1001 K(14) P(2) 0101 0101 0000 1001 0101 0101 0000 0001 K(15) P(1) 0101 0101 0000 0001 K(15) P(2) K(16) P(1) 0101 0101 0000 0001 K(16) P(2) 0101 0101 1110 1001 \$End write cycle.

The logic analyzer results indicate that the MC68000 returns both the address and data bus to the high impedance state at phase one of clock cycle five. This phase begins a two-cycle sequence of micro-operations that compute the destination address by adding both the displacement and the contents of the index register to the value contained in address register Al. The microstatements that return the bus to the high impedance state were not present in the CDL model. The assignments "ADENABLE = lo" and "DBENABLE = lo" were added to the ISP' model of this instruction to correct this omission.

There were also the usual deviations relative to the high impedance state on the address bus at the start of read and write cycles. These occurred at phase one of clock cycles zero and 12.

## MOVE\_W D1,\$2004

MOVE.W D1,\$2004 uses the data register direct and absolute short addressing modes to move the contents of data register D1 to the memory locations beginning at address 2004. This two-word instruction required 15 clock cycles to execute its two read and one write cycles. As with the previous instruction, the four least significant address and data lines were monitored. The simulation results were:

|                |              | 15-12<br>AAAA<br>4321 | 11-8<br>DDDD<br>3210                    | 74<br>AULR<br>SDD/<br>SSW | 30<br>DFFF<br>TCCC<br>A210<br>C<br>K | (columns)<br>(signals)                                                                      |
|----------------|--------------|-----------------------|-----------------------------------------|---------------------------|--------------------------------------|---------------------------------------------------------------------------------------------|
| K ( 0 )        | P(1)         | 1111                  | 1111                                    | 1111                      | 1010                                 | <pre>\$Begin read cycle. \$Address lines (12-15) \$are 1005 location of</pre>               |
| K ( 0 )        | P(2)         | 0011                  | 1111                                    | 1111                      | 1010                                 |                                                                                             |
| K(l)           | P(1)         | 0011                  | 1111                                    | 0001                      | 1010                                 | Sinstruction being                                                                          |
| K(l)           | P(2)         | 0011                  | 1111                                    | 0001                      | 1010                                 | Sprefetched                                                                                 |
| K(2)<br>K(2)   | P(1)<br>P(2) | 0011<br>0011          | $\begin{array}{c}1111\\1111\end{array}$ | 0001<br>0001              | 1010<br>1010                         |                                                                                             |
| K(3)<br>K(3)   | P(1)<br>P(2) | 0011<br>0011          | 0100<br>0100                            | 0001<br>0001              | 0010<br>0010                         | <pre>\$Data applied to data bus<br/>\$(8-11). Data is 04,<br/>\$the displacement</pre>      |
| K(4)           | P(1)         | 0011                  | 0100                                    | 0001                      | 0010                                 | \$End read cycle.                                                                           |
| K(4)           | P(2)         | 0011                  | 0100                                    | 1111                      | 1010                                 |                                                                                             |
| K (5)          | P(1)         | 1111                  | 1111                                    | 1111                      | 1010                                 | <pre>\$Begin read cycle. \$Address lines (12-15) \$Address lines (12-15)</pre>              |
| K (5)          | P(2)         | 0100                  | 1111                                    | 1111                      | 1010                                 |                                                                                             |
| K (6)          | P(1)         | 0100                  | $\begin{array}{c}1111\\1111\end{array}$ | 0001                      | 1010                                 | Sinstruction being                                                                          |
| K (6)          | P(2)         | 0100                  |                                         | 0001                      | 1010                                 | Sprefetched.                                                                                |
| K(7)           | P(1)         | 0100                  | 1111                                    | 0001                      | 1010                                 |                                                                                             |
| K(7)           | P(2)         | 0100                  | 1111                                    | 0001                      | 1010                                 |                                                                                             |
| K(8)<br>K(8)   | P(1)<br>P(2) | 0100<br>0100          | 0001<br>0001                            | 0001<br>0001              | 0010<br>0010                         | <pre>\$Data applied to data bus<br/>\$(8-11). Data is code<br/>\$for MOVE W D1 \$2008</pre> |
| K (9)          | P(1)         | 0100                  | 0001                                    | 0001                      | 0010                                 | \$End read cycle.                                                                           |
| K (9)          | P(2)         | 0100                  | 0001                                    | 1111                      | 1010                                 |                                                                                             |
| K(10)          | P(1)         | 1111                  | 1111                                    | 1111                      | 1010                                 | <pre>\$Begin write cycle. \$Address lines (12-15) \$are 2004</pre>                          |
| K(10)          | F(2)         | 0010                  | 1111                                    | 1111                      | 1001                                 |                                                                                             |
| K(ll)          | P(1)         | 0010                  | 1111                                    | 0110                      | 1001                                 | \$Data put on data bus                                                                      |
| K(ll)          | P(2)         | 0010                  | 0101                                    | 0110                      | 1001                                 |                                                                                             |
| K(12)<br>K(12) | P(1)<br>P(2) | 0010<br>0010          | 0101<br>0101                            | 0000                      | 1001<br>1001                         | \$data being moved.                                                                         |
| K(13)<br>K(12) | P(1)<br>P(2) | 0010<br>0010          | 0101<br>0101                            | 0000                      | 1001<br>1001                         |                                                                                             |
| K(13)<br>K(13) | P(1)<br>P(2) | 0010<br>0010          | 0101<br>0101                            | 0000                      | 0001<br>0001                         |                                                                                             |
| K(14)          | P(1)         | 0010                  | 0101                                    | 0000                      | 0001                                 |                                                                                             |

.

2

VI-24

•

K(14) P(2) 0010 0101 1110 1001 \$End write cycle.

The only differences occurred at phase one of clock cycles zero and ten where the logic analyzer again did not let the address bus complete its return to the high impedance state.

## MOVE W AL.D3

MOVE.W Al,D3 is a single-word instruction that uses the address register direct and data register direct addressing modes to move the contents of address register Al to data register D3. It consists of a single read cycle (instruction prefetch) that required five clock cycles to execute. No address lines were monitored during this simulation. The results were:

|                |              | 15-12<br>DDDD<br>7654 | 11-8<br>DDDD<br>3210 | 74<br>AULR<br>SDD/<br>SSW | 30<br>DFFF<br>TCCC<br>A210<br>C<br>K | (columns)<br>(signals)                                                                   |
|----------------|--------------|-----------------------|----------------------|---------------------------|--------------------------------------|------------------------------------------------------------------------------------------|
| K ( 0 )        | P(1)         | 1111                  | 1111                 | 1111                      | 1010                                 | \$Begin read cycle.                                                                      |
| K ( 0 )        | P(2)         | 1111                  | 1111                 | 1111                      | 1010                                 |                                                                                          |
| K(l)           | P(1)         | 1111                  | 1111                 | 0001                      | 1010                                 |                                                                                          |
| K(l)           | P(2)         | 1111                  | 1111                 | 0001                      | 1010                                 |                                                                                          |
| K(2)           | P(1)         | 1111                  | 1111                 | 0001                      | 1010                                 |                                                                                          |
| K(2)           | P(2)         | 1111                  | 1111                 | 0001                      | 1010                                 |                                                                                          |
| K (3)<br>K (3) | P(1)<br>P(2) | 0000                  | 1001<br>1001         | 0001<br>0001              | 0010<br>0010                         | <pre>\$Data applied to data bus<br/>\$(8-15). Data is code<br/>\$for MOVE.W Al.D3.</pre> |
| K(4)           | P(1)         | 0000                  | 1001                 | 0001                      | 0010                                 | \$End read cycle.                                                                        |
| K(4)           | P(2)         | 0000                  | 1001                 | 1111                      | 1010                                 |                                                                                          |

At phase one of clock cycle zero of their CDL model,

Hamby and Guillory included the microstatement "IDBUS <-Al(LWORD)" to place the low word of address register Al onto the internal data bus. Subregister Al(LWORD) did not appear in the declaration section of their CDL model but was added to the ISP' version of this instruction.

At phase two of clock cycle two the logic analyzer shows the data bus changed from the high impedance state of the previous cycle to "1011 1111" on its way to the valid data state "0000 1001" at phase one of clock cycle three. As occurred during the MOVE.L D1,A1 simulation, the logic analyzer caught the bus transitioning to high impedance whereas the simulation shows the process completed.

### MOVE W (A1), D2

MOVE.W (A1),D2 uses the address register indirect and data register direct addressing modes to move the contents of the memory locations pointed to by address register Al to data register D2. This single-word instruction required 10 clock cycles to execute its two read cycles. Both the simulation and logic analyzer results were in agreement. No address lines were monitored during the simulation. The results were:

15-12 11-8 7--4 3--0 (columns)
DDDD DDDD AULR DFFF (signals)
7654 3210 SDD/ TCCC
SSW A210
C
K

1111 1111 0001 1010 R(1) P(1) K(1) P(2)1111 1111 0001 1010 K(2) P(1) 1111 1111 0001 1010 K(2) P(2) 1111 1111 0001 1010 0001 0001 0001 0010 \$Data applied to data bus K(3) P(1) 0001 0001 0001 0010 \$(8-15). Data is code K(3) P(2) \$for MOVE.W (Al),D2. 0001 0001 0001 0010 K(4) P(1) K(4) P(2) 0001 0001 1111 1010 \$End read cycle. K(5) P(1) 1111 1111 1111 1010 \$Begin read cycle. 1111 1111 1111 1001 \$Function codes (0-2) K(5) P(2) \$change to user data 1111 1111 0001 1001 \$mode. K(6) P(1) 1111 1111 0001 1001 K(6) P(2) K(7) P(1) 1111 1111 0001 1001 K(7) P(2)1111 1111 0001 1001 K(8) P(1) 0101 0101 0001 0001 \$Data applied to data bus K(8) P(2) 0101 0101 0001 0001 \$(8-15). Data is 55 hex, \$data being moved. K(9) P(1) 0101 0101 0001 0001 K(9) P(2) 0101 0101 1111 1001 \$End read cycle.

### MOVE W (A1) +, D6

MOVE.W (Al)+,D6 uses the postincrement register indirect and data register direct addressing modes to move the contents of the memory locations pointed to by address register Al to data register D6. Address register Al is incremented by two after being used as a pointer. This single-word instruction required 10 clock cycles to execute its two read cycles. The four least significant address and data lines were monitored during the simulation. The results were:

|                |              | 15-12<br>AAAA<br>4321 | 11-8<br>DDDD<br>3210 | 74<br>AULR<br>SDD/<br>SSW | 30<br>DFFF<br>TCCC<br>A210<br>C<br>K | (columns)<br>(signals)                                                                     |
|----------------|--------------|-----------------------|----------------------|---------------------------|--------------------------------------|--------------------------------------------------------------------------------------------|
| K ( 0 )        | P(1)         | 1111                  | 1111                 | 1111                      | 1010                                 | <pre>\$Begin read cycle. \$Address lines (12-15) \$are 1006 location of</pre>              |
| K ( 0 )        | P(2)         | 0011                  | 1111                 | 1111                      | 1010                                 |                                                                                            |
| K(l)           | P(1)         | 0011                  | 1111                 | 0001                      | 1010                                 | Sinstruction being                                                                         |
| K(l)           | P(2)         | 0011                  | 1111                 | 0001                      | 1010                                 | Sprefetched                                                                                |
| K(2)           | P(1)         | 0011                  | 1111                 | 0001                      | 1010                                 |                                                                                            |
| K(2)           | P(2)         | 0011                  | 1111                 | 0001                      | 1010                                 |                                                                                            |
| K (3)<br>K (3) | P(1)<br>P(2) | 0011<br>0011          | 1001<br>1001         | 0001<br>0001              | 0010<br>0010                         | \$Data applied to data bus<br>\$(8-11). Data is code<br>\$for MOVE W (A1)+ D7              |
| K (4)          | P(1)         | 0011                  | 1001                 | 0001                      | 0010                                 | \$End read cycle.                                                                          |
| K (4)          | P(2)         | 0011                  | 1001                 | 1111                      | 1010                                 |                                                                                            |
| K(5)<br>K(5)   | P(1)<br>P(2) | 1111<br>0000          | 1111<br>1111         | 1111<br>1111              | 1010<br>1001                         | <pre>\$Begin read cycle.<br/>\$Address lines (12-15)<br/>\$are 2000 box location of</pre>  |
| K (6)          | P(1)         | 0000                  | 1111                 | 0001                      | 1001                                 | Sof data. Function codes                                                                   |
| K (6)          | P(2)         | 0000                  | 1111                 | 0001                      | 1001                                 | \$(0-2) change to user                                                                     |
| K (7)          | P(1)         | 0000                  | 1111                 | 0001                      | 1001                                 | suara mode.                                                                                |
| K (7)          | P(2)         | 0000                  | 1111                 | 0001                      | 1001                                 |                                                                                            |
| K (8)<br>K (8) | P(1)<br>P(2) | 0000<br>0000          | 0101<br>0101         | 0001<br>0001              | 0001<br>0001                         | <pre>\$Data applied to data bus<br/>\$(8-11). Data is 5 hex,<br/>\$data being merced</pre> |
| K (9)<br>K (9) | P(1)<br>P(2) | 0000                  | 0101<br>0101         | 0001<br>1111              | 0001<br>1001                         | \$End read cycle.                                                                          |

The simulation results again differed from the logic analyzer data only on the address bus where the logic analyzer failed to capture its high impedance state at phase one of clock cycle zero and five.

# MOVE.W - (A1), D4

MOVE.W -(A1), D4 uses the predecrement register indirect and data register direct addressing modes to move the

contents of the memory locations pointed to by address register Al to data register D4. Address register Al is decremented by two before being used as a pointer. This single-word instruction required 12 clock cycles to execute its two read cycles. The four least significant address and data lines were monitored during the simulation. The results were:

15-12 11-8 7--4 3--0 (columns) AAAA DDDD AULR DFFF (signals) 4321 3210 SDD/ TCCC SSW A210 С K 1111 1111 1111 1010 \$Begin read cycle. K(0) P(1)K(0) P(2) 0011 1111 1111 1010 \$Address lines (12-15) Sare 1006, location of 0011 1111 0001 1010 \$instruction being K(1) P(1) K(1) P(2) 0011 1111 0001 1010 \$prefetched 0011 1111 0001 1010 K(2) P(1)0011 1111 0001 1010 K(2) P(2) 0011 0001 0001 0010 \$Data applied to data bus K(3) P(1) K(3) P(2)0011 0001 0001 0010 \$(8-11). Data is code for MOVE.W - (Al), D3.0011 0001 0001 0010 K(4) P(1) 0011 0001 1111 1010 \$End read cycle. K(4) P(2) 1111 1111 1111 1010 \$Address and data K(5) P(1) K(5) P(2)1111 1111 1111 1010 \$buses (8-15) go high. K(6) P(1) 1111 1111 1111 1010 K(6) P(2) 1111 1111 1111 1010 1111 1111 1111 1010 \$Begin read cycle. K(7) P(1) K(7) P(2)0011 1111 1111 1001 \$Address lines (12-15) Sare 2006, location of K(8) P(1) 0011 1111 0001 1001 \$data. Function codes K(8) P(2) 0011 1111 0001 1001 \$(0-2) change to user \$data mode. K(9) P(1) 0011 1111 0001 1001 K(9) P(2)0011 1111 0001 1001 0011 0101 0001 0001 \$Data applied to data bus K(10) P(1)

The logic analyzer results indicate that the MC68000 returns both the address and data bus to the high impedance state at phase one of clock cycle five. This phase begins a two-cycle sequence in which address register Al is decremented. The microstatements that return the bus to the high impedance state were not present in the CDL model. The assignments "ADENABLE = lo" and "DNENABLE = lo" were added to the ISP' model of this instruction to correct this omission.

There were also the usual deviations relative to the high impedance state on the address bus at the start of read and write cycles. These occurred at phase one of clock cycles zero and 5.

### MOVE W 04(A1),D1

The MOVE.W 04(A1),D1 instruction uses the data register direct and register indirect with offset addressing modes to move the contents of the memory locations determined by the sum of the displacement (4 - located in the instruction's extention word) and the contents of address register A1. This two-word instruction required 15 clock cycles to execute its three read cycles. No address lines were monitored during the simulation. The results were:

15-12 11-8 7--4 3--0 (columns) DDDD DDDD AULR DFFF (signals) 7654 3210 SDD/ TCCC SSW A210 K 1111 1111 1111 1010 \$Begin read cycle. K(0) P(1) K(0) P(2) 1111 1111 1111 1010 K(1) P(1)1111 1111 0001 1010 1111 1111 0001 1010 K(1) P(2) 1111 1111 0001 1010 K(2) P(1)K(2) P(2)1111 1111 0001 1010 0000 0100 0001 0010 \$Data applied to data bus K(3) P(1) K(3) P(2) 0000 0100 0001 0010 \$(8-15). Data is 4 hex, \$the displacement. 0000 0100 0001 0010 K(4) P(1) 0000 0100 1111 1010 \$End read cycle. K(4) P(2)1111 1111 1111 1010 \$Begin read cycle. K(5) P(1)K(5) P(2)1111 1111 1111 1010 K(6) P(1) 1111 1111 0001 1010 K(6) P(2)1111 1111 0001 1010 K(7) P(1) 1111 1111 0001 1010 K(7) P(2)1111 1111 0001 1010 K(8) P(1) 0010 1001 0001 0010 \$Data applied to data bus K(8) P(2) 0010 1001 0001 0010 \$(8-15). Data is code \$for MOVE.W 08(A1),D2. 0010 1001 0001 0010 K(9) P(1) K(9) P(2) 0010 1001 1111 1010 \$End read cycle. 1111 1111 1111 1010 \$Begin read cycle. K(10) P(1) 1111 1111 1111 1001 \$Function codes (0-2) K(10) P(2) \$change to user data K(11) P(1) 1111 1111 0001 1001 \$mode. K(11) P(2) 1111 1111 0001 1001 K(12) P(1) 1111 1111 0001 1001 1111 1111 0001 1001 K(12) P(2) 0101 0101 0001 0001 \$Data applied to data bus K(13) P(1) 0101 0101 0001 0001 \$(8-15). Data is 55 hex, K(13) P(2) \$data being moved. 0101 0101 0001 0001 K(14) P(1) K(14) P(2) 0101 0101 1111 1001 \$End read cycle.

The only difference between the simulation and logic analyzer data appeared on the data bus at phase two of clock cycle two. Here the logic analyzer caught the bus transitioning to a valid data state from high impedance whereas the simulation maintained high impedance.

### MOVE.W 04(A1,D7),D2

MOVE.W 04(Al,D7),D2 is a two-word instruction that uses the indexed register indirect with offset and data register direct addressing modes to move the contents of the memory locations determined by the sum of the index register D7, the displacement (4), and the contents of address register Al, to data register D2. This instruction required 17 clock cycles to complete its three read cycles. The four least significant address and data lines were monitored during the simulation. The results were:

|                |              | 15-12<br>AAAA<br>4321 | 11-8<br>DDDD<br>3210                    | 74<br>AULR<br>SDD/<br>SSW | 30<br>DFFF<br>TCCC<br>A210<br>C<br>K | (columns)<br>(signals)                                                                   |
|----------------|--------------|-----------------------|-----------------------------------------|---------------------------|--------------------------------------|------------------------------------------------------------------------------------------|
| K ( 0 )        | P(1)         | 1111                  | 1111                                    | 1111                      | 1010                                 | <pre>\$Begin read cycle. \$Address lines (12-15) Sare 1006, location of</pre>            |
| K ( 0 )        | P(2)         | 0011                  | 1111                                    | 1111                      | 1010                                 |                                                                                          |
| K(l)           | P(1)         | 0011                  | $\begin{array}{c}1111\\1111\end{array}$ | 0001                      | 1010                                 | Sinstruction being                                                                       |
| K(l)           | P(2)         | 0011                  |                                         | 0001                      | 1010                                 | Sprefetched                                                                              |
| K (2)<br>K (2) | P(1)<br>P(2) | 0011<br>0011          | $\begin{array}{c}1111\\1111\end{array}$ | 0001<br>0001              | 1010<br>1010                         |                                                                                          |
| K (3)<br>K (3) | P(1)<br>P(2) | 0011<br>0011          | 0100<br>0100                            | 0001<br>0001              | 0010<br>0010                         | <pre>\$Data applied to data bus<br/>\$(8-11). Data is 4 hex,<br/>Sthe displacement</pre> |
| K(4)           | P(1)         | 0011                  | 0100                                    | 0001                      | 0010                                 | Send read cycle.                                                                         |
| K(4)           | P(2)         | 0011                  | 0100                                    | 1111                      | 1010                                 |                                                                                          |

1111 1111 1111 1010 \$Address and data K(5) P(1) K(5) P(2) 1111 1111 1111 1010 \$buses (8-15) go high. K(6) P(1) 1111 1111 1111 1010 K(6) P(2) 1111 1111 1111 1010 K(7) P(1)1111 1111 1111 1010 \$Begin read cycle. K(7) P(2)0100 1111 1111 1010 \$Address lines (12-15) \$are 1008, location of K(8) P(1) 0100 1111 0001 1010 Sinstruction being K(8) P(2) 0100 1111 0001 1010 \$prefetched. K(9) P(1) 0100 1111 0001 1010 K(9) P(2) 0100 1111 0001 1010 K(10) P(1) 0100 0001 0001 0010 \$Data applied to data bus K(10) P(2) 0100 0001 0001 0010 \$(8-11). Data is code \$for MOVE.W 04(A1,D7),D3. 0100 0001 0001 0010 K(11) P(1) K(11) P(2) 0100 0001 1111 1010 \$End read cycle. K(12) P(1) 1111 1111 1111 1010 \$Begin read cycle. 0101 1111 1111 1001 \$Address lines (12-15) K(12) P(2) \$are 200A, location of 0101 1111 0001 1001 \$of data. Function codes K(13) P(1) K(13) P(2) 0101 1111 0001 1001 \$(0-2) change to user \$data mode. 0101 1111 0001 1001 K(14) P(1) 0101 1111 0001 1001 K(14) P(2) 0101 0101 0001 0001 \$Data applied to data bus K(15) P(1) K(15) P(2) 0101 0101 0001 0001 \$(8-11). Data is 5 hex, \$data being moved. 0101 0101 0001 0001 K(16) P(1) 0101 0101 1111 1001 \$End read cycle. K(16) P(2)

The logic analyzer results indicate that the MC68000 returns both the address and data bus to the high impedance state at phase one of clock cycle five. This phase begins a two-cycle sequence in which the index register D7 is added to the displacement register (DISREG). The microstatements that return the bus to the high impedance state were not present in the CDL model. The assignments "ADENABLE = lo" and "DBENABLE = lo" were added to the ISP' model of this instruction to correct this omission. There were also the usual deviations relative to the high impedance state on the address bus at the start of read and write cycles. These occurred at phase one of clock cycles zero and 12.

### MOVE.W \$2004.D5

MOVE.W \$2004,D5 uses the absolute short and data register direct addressing modes to move the data word at memory location 2004 into data register D5. This two-word instruction required 15 clock cycles to complete its three read cycles. The four least significant address and data signals were monitored during the simulation. The results were:

|       |       | 15-12<br>AAAA<br>4321 | 11-8<br>DDDD<br>3210 | 74<br>AULR<br>SDD/<br>SSW | 30<br>DFFF<br>TCCC<br>A210<br>C<br>K | (columns)<br>(signals)    |
|-------|-------|-----------------------|----------------------|---------------------------|--------------------------------------|---------------------------|
| K (0) | P(1)  | 1111                  | 1111                 | 1111                      | 1010                                 | SBegin read cycle.        |
| K(0)  | P(2)  | 0011                  | 1111                 | 1111                      | 1010                                 | \$Address lines (12-15)   |
|       |       |                       |                      |                           |                                      | Sare 1006, location of    |
| K(1)  | P(1)  | 0011                  | 1111                 | 0001                      | 1010                                 | \$instruction being       |
| K(l)  | P(2)  | 0011                  | 1111                 | 0001                      | 1010                                 | <pre>\$prefetched</pre>   |
|       |       |                       |                      |                           |                                      |                           |
| K(2)  | P(1)  | 0011                  | 1111                 | 0001                      | 1010                                 |                           |
| K(2)  | P(2)  | 0011                  | 1111                 | 0001                      | 1010                                 |                           |
| K(3)  | P(1)  | 0011                  | 0100                 | 1000                      | 0010                                 | SData applied to data bus |
| K(3)  | P(2)  | 0011                  | 0100                 | 0001                      | 0010                                 | S(8-11). Data is 4 hex.   |
| (-)   | - (-/ |                       | 0200                 |                           |                                      | Slow byte of operand      |
| K(4)  | P(1)  | 0011                  | 0100                 | 0001                      | 0010                                 | Saddress.                 |
| K (4) | P(2)  | 0011                  | 0100                 | 1111                      | 1010                                 | \$End read cycle.         |
|       |       |                       |                      |                           |                                      | -                         |
| K(5)  | P(1)  | 1111                  | 1111                 | 1111                      | 1010                                 | \$Begin read cycle.       |
| K(5)  | P(2)  | 0100                  | 1111                 | 1111                      | 1010                                 | \$Address lines (12-15)   |
|       |       |                       |                      |                           |                                      | \$are 1008, location of   |
| K(6)  | P(1)  | 0100                  | 1111                 | 0001                      | 1010                                 | \$instruction being       |
| K(6)  | P(2)  | 0100                  | 1111                 | 0001                      | 1010                                 | <pre>\$prefetched.</pre>  |

K(7) P(1) 0100 1111 0001 1010 0100 1111 0001 1010 K(7) P(2) K(8) P(1) 0100 1000 0001 0010 \$Data applied to data bus K(8) P(2) 0100 1000 0001 0010 \$(8-11). Data is code \$for MOVE.W \$2004,D6. K(9) P(1) 0100 1000 0001 0010 K(9) P(2) 0100 1000 1111 1010 \$End read cycle. K(10) P(1) 1111 1111 1111 1010 \$Begin read cycle. K(10) P(2) 0010 1111 1111 1001 \$Address lines (12-15) \$are 2004, location of 0010 1111 0001 1001 \$of data. Function codes K(11) P(1) K(11) P(2) 0010 1111 0001 1001 \$(0-2) change to user \$data mode. 0010 1111 0001 1001 K(12) P(1) K(12) P(2) 0010 1111 0001 1001 0010 0101 0001 0001 \$Data applied to data bus K(13) P(1) K(13) P(2) 0010 0101 0001 0001 \$(8-11). Data is 5 hex, \$data being moved. 0010 0101 0001 0001 K(14) P(1) 0010 0101 1111 1001 \$End read cycle. K(14) P(2)

The usual deviations relative to the high impedance state on the address bus at the start of a read cycle occurred at phase one of clock cycles zero and 10.

#### MOVE.W \$2004,\$2008

MOVE.W \$2008,\$2004 uses the absolute long addressing mode to move the data word beginning at memory location 2004 to 2008. This instruction is five words long and requires 35 clock cycles to complete its six read and one write cycles. No address lines were monitored. The simulation results were:

> 15-12 11-8 7--4 3--0 (columns) DDDD DDDD AULR DFFF (signals) 7654 3210 SDD/ TCCC SSW A210 C K

| K ( 0 )        | P(1)         | 1111 1111                                                                | 1111 1010              | SBegin read cycle.                                                                            |
|----------------|--------------|--------------------------------------------------------------------------|------------------------|-----------------------------------------------------------------------------------------------|
| K ( 0 )        | P(2)         | 1111 1111                                                                | 1111 1010              |                                                                                               |
| K(1)<br>K(1)   | P(1)<br>P(2) | $\begin{array}{c} 1111 & 1111 \\ 1111 & 1111 \\ 1111 & 1111 \end{array}$ | 0001 1010<br>0001 1010 |                                                                                               |
| K(2)           | P(1)         | 1111 1111                                                                | 0001 1010              |                                                                                               |
| K(2)           | P(2)         | 1111 1111                                                                | 0001 1010              |                                                                                               |
| K(3)<br>K(3)   | P(1)<br>P(2) | 0000 0000<br>0000 0000                                                   | 0001 0010<br>0001 0010 | <pre>\$Data applied to data bus<br/>\$(8-15). Data is high<br/>\$word of source address</pre> |
| K (4)          | P(1)         | 0000 0000                                                                | 0001 0010              | \$End read cycle.                                                                             |
| K (4)          | P(2)         | 0000 0000                                                                | 1111 1010              |                                                                                               |
| K(5)<br>K(5)   | P(1)<br>P(2) | $\begin{array}{cccccccccccccccccccccccccccccccccccc$                     | 1111 1010<br>1111 1010 | \$Begin read cycle.                                                                           |
| K (6)          | P(1)         | 1111 1111                                                                | 0001 1010              |                                                                                               |
| K (6)          | P(2)         | 1111 1111                                                                | 0001 1010              |                                                                                               |
| K(7)<br>K(7)   | P(1)<br>P(2) | $\begin{array}{c} 1111 & 1111 \\ 1111 & 1111 \\ 1111 & 1111 \end{array}$ | 0001 1010<br>0001 1010 |                                                                                               |
| K (8)          | P(1)         | 0000 0100                                                                | 0001 0010              | \$Data applied to data bus                                                                    |
| K (8)          | P(2)         | 0000 0100                                                                | 0001 0010              | \$(8-15). Data is low                                                                         |
| K (9)          | P(1)         | 0000 0100                                                                | 0001 0010              | \$End read cycle.                                                                             |
| K (9)          | P(2)         | 0000 0100                                                                | 1111 1010              |                                                                                               |
| K(10)          | P(1)         | 1111 1111                                                                | 1111 1010              | \$Begin read cycle.                                                                           |
| K(10)          | P(2)         | 1111 1111                                                                | 1111 1010              |                                                                                               |
| K(11)          | P(1)         | 1111 1111                                                                | 0001 1010              |                                                                                               |
| K(11)          | P(2)         | 1111 1111                                                                | 0001 1010              |                                                                                               |
| K(12)<br>K(12) | P(1)<br>P(2) | $\begin{array}{c} 1111 & 1111 \\ 1111 & 1111 \\ 1111 & 1111 \end{array}$ | 0001 1010<br>0001 1010 |                                                                                               |
| K(13)          | P(1)         | 0000 0000                                                                | 0001 0010              | \$Data applied to data bus                                                                    |
| K(13)          | P(2)         | 0000 0000                                                                | 0001 0010              | \$(8-15). Data is high                                                                        |
| K(14)          | P(1)         | 0000 0000                                                                | 0001 0010              | \$End read cycle.                                                                             |
| K(14)          | P(2)         | 0000 0000                                                                | 1111 1010              |                                                                                               |
| K(15)          | P(1)         | $\begin{array}{c} 1111 & 1111 \\ 1111 & 1111 \\ 1111 & 1111 \end{array}$ | 1111 1010              | SBegin read cycle.                                                                            |
| K(15)          | P(2)         |                                                                          | 1111 1001              | SFunction codes (0-2)                                                                         |
| K(16)          | P(1)         | 1111 1111                                                                | 0001 1001              | \$mode.                                                                                       |
| K(16)          | P(2)         | 1111 1111                                                                | 0001 1001              |                                                                                               |
| K(17)          | P(1)         | 1111 1111                                                                | 0001 1001              |                                                                                               |
| K(17)          | P(2)         | 1111 1111                                                                | 0001 1001              |                                                                                               |

( 🔴

K(18) P(1) 0101 0101 0001 0001 \$Data applied to data bus K(18) P(2) 0101 0101 0001 0001 \$(8-15). Data is 55 hex, Sdata being moved. K(19) P(1) 0101 0101 0001 0001 K(19) P(2) 0101 0101 1111 1001 \$End read cycle. K(20) P(1) 1111 1111 1111 1001 \$Begin read cycle. K(20) P(2) 1111 1111 1111 1010 \$Function codes (0-2) \$change to user program K(21) P(1) 1111 1111 0001 1010 \$mode. K(21) P(2) 1111 1111 0001 1010 K(22) P(1) 1111 1111 0001 1010 K(22) P(2) 1111 1111 0001 1010 0000 1000 0001 0010 \$Data applied to data bus K(23) P(1) K(23) P(2) 0000 1000 0001 0010 \$(8-15). Data is low word Sof destination. K(24) P(1) 0000 1000 0001 0010 K(24) P(2) 0000 1000 1111 1010 \$End read cycle. K(25) P(1) 1111 1111 1111 1010 \$Begin write cycle. K(25) P(2) 1111 1111 1111 1001 \$Function codes (0-2) \$change to user data mode. 1111 1111 0110 1001 K(26) P(1) 0101 0101 0110 1001 \$Data put on data bus K(26) P(2) \$(8-15). Data is 55 hex, K(27) P(1) 0101 0101 0000 1001 \$data being moved. K(27) P(2) 0101 0101 0000 1001 K(28) P(1) 0101 0101 0000 1001 K(27) P(2) 0101 0101 0000 1001 K(28) P(1) 0101 0101 0000 0001 K(28) P(2) 0101 0101 0000 0001 K(29) P(1) 0101 0101 0000 0001 0101 0101 1110 1001 \$End write cycle. K(29) P(2) K(30) P(1) 1111 1111 1111 1001 \$Begin read cycle. K(30) P(2) 1111 1111 1111 1010 \$Function codes (0-2) Schange to user program K(31) P(1) 1111 1111 0001 1010 \$mode. 1111 1111 0001 1010 K(31) P(2) K(32) P(1) 1111 1111 0001 1010 K(32) P(2) 1111 1111 0001 1010 1101 0000 0001 0010 \$Data applied to data bus K(33) P(1) K(33) P(2) 1101 0000 0001 0010 \$(8-15). Data is code \$for JMP, so this is K(34) P(1) 1101 0000 0001 0010 \$a prefetch. K(34) P(2) 1101 0000 1111 1010 \$End read cycle.

All differences between the simulation and logic analyzer data occur on the data bus. At phase two of clock cycles 2, 7, 12, 22, and 26 the logic analyzer catches the data bus transitioning to a valid data state. There is also a difference at phase one of clock cycle 30. Because this cycle follows a write cycle, the data buses'return to the high impedance state is hot captured until phase two.

### MOVE.W #\$5555.D1

MOVE.W #\$5555,Dl uses the immediate and data register direct addressing modes to move the hex value 5555 into data register Dl. This is a two-word instruction that requires 10 clock cycles to complete its two read cycles. The four least significant signals on the address and data bus were monitored during the simulation. The results were:

|                |              | 15-12<br>AAAA<br>4321 | 11-8<br>DDDD<br>3210                    | 74<br>AULR<br>SDD/<br>SSW | 30<br>DFFF<br>TCCC<br>A210<br>C<br>K | (columns)<br>(signals)                                                                  |
|----------------|--------------|-----------------------|-----------------------------------------|---------------------------|--------------------------------------|-----------------------------------------------------------------------------------------|
| K (0)<br>K (0) | P(1)<br>P(2) | 1111<br>0011          | 1111<br>1111                            | 1111<br>1111              | 1010<br>1010                         | \$Begin read cycle.<br>\$Address lines (12-15)<br>Sare 1006. location of                |
| K(l)<br>K(l)   | P(1)<br>P(2) | 0011<br>0011          | $\begin{array}{c}1111\\1111\end{array}$ | 0001<br>0001              | 1010<br>1010                         | Simmediate data.                                                                        |
| K (2)<br>K (2) | P(1)<br>P(?) | 0011<br>0011          | $\begin{array}{c}1111\\1111\end{array}$ | 0001<br>0001              | 1010<br>1010                         |                                                                                         |
| K (3)<br>K (3) | P(1)<br>P(2) | 0011<br>0011          | 0101<br>0101                            | 0001<br>0001              | 0010<br>0010                         | <pre>\$Data applied to data bus<br/>\$(8-11). Data is 5 hex,<br/>Simmediate data.</pre> |
| K (4)<br>K (4) | P(1)<br>P(2) | 0011<br>0011          | 0101<br>0101                            | 0001<br>1111              | 0010<br>1010                         | \$End read cycle.                                                                       |
| K(5)           | P(1)         | 1111                  | 1111                                    | 1111                      | 1010                                 | \$Begin read cycle.                                                                     |

| K(5)         | P(2)         | 0100 1111              | 1111 1010              | \$Address lines (12-15)<br>Sare 1008, location of                                             |
|--------------|--------------|------------------------|------------------------|-----------------------------------------------------------------------------------------------|
| K(6)         | P(1)         | 0100 1111              | 0001 1010              | Sinstruction being                                                                            |
| K(6)         | P(2)         | 0100 1111              | 0001 1010              | Sprefetched.                                                                                  |
| K(7)         | P(1)         | 0100 1111              | 0001 1010              |                                                                                               |
| K(7)         | P(2)         | 0100 1111              | 0001 1010              |                                                                                               |
| K(8)<br>K(8) | P(1)<br>P(2) | 0100 1100<br>0100 1100 | 0001 0010<br>0001 0010 | <pre>\$Data applied to data bus<br/>\$(8-11). Data is code<br/>\$for MOVE.W #\$5555.D1.</pre> |
| K (9)        | P(1)         | 0100 1100              | 0001 0010              | \$End read cycle.                                                                             |
| K (9)        | P(2)         | 0100 1100              | 1111 1010              |                                                                                               |

A difference occurs at phase one of clock cycle zero where the logic analyzer captured the address bus transitioning to the high impedance state whereas the simulation fully reflects high impedance. Also, at phase one of clock cycle nine, the logic analyzer data shows a data bus state change where one should clearly not occur. This is certainly a typing error.

### JMP (AO)

JMP (A0) uses the register indirect addressing mode to direct the MC68000 to next execute the instruction located at the address pointed to by address register A0. This instruction ended all instruction test routines creating a loop in which the instruction of interest was continually executed. JMP is a single-word instruction that requires 10 clock cycles to execute its two read cycles (instruction prefetches). The simulation and logic analyzer results were equivalent. No address lines were monitored during the simulation. The results were:

|                    |              | 15-12<br>DDDD<br>7654                   | 11-8<br>DDDD<br>3210 | 74<br>AULR<br>SDD/<br>SSW | 30<br>DFFF<br>TCCC<br>A210<br>C<br>K | (columns)<br>(signals)                                                                    |
|--------------------|--------------|-----------------------------------------|----------------------|---------------------------|--------------------------------------|-------------------------------------------------------------------------------------------|
| K ( 0 )<br>K ( 0 ) | P(1)<br>P(2) | 1111<br>1111                            | 1111<br>1111         | 1111<br>1111              | 1010<br>1010                         | \$Begin read cycle.                                                                       |
| K(l)<br>K(l)       | P(1)<br>P(2) | $\begin{array}{c}1111\\1111\end{array}$ | 1111<br>1111         | 0001<br>0001              | 1010<br>1010                         |                                                                                           |
| K(2)<br>K(2)       | P(1)<br>P(2) | $\begin{array}{c}1111\\1111\end{array}$ | 1111<br>1111         | 0001<br>0001              | 1010<br>1010                         |                                                                                           |
| K (3)<br>K (3)     | P(1)<br>P(2) | 1111<br>1111                            | 1111<br>1111         | 0001<br>0001              | 0010<br>0010                         | \$Data applied to data bus<br>\$(8-15). Data is all ones<br>Shecause this a prefetch      |
| K(4)<br>K(4)       | P(1)<br>P(2) | 1111<br>1111                            | 1111                 | 0001                      | 0010                                 | \$and there are no instruct-<br>\$ions following the JMP<br>\$(unused memory is all 1's). |
| K(5)<br>K(5)       | P(1)<br>P(2) | 1111<br>1111                            | 1111<br>1111         | 1111<br>1111              | 1010<br>1010                         | \$Begin read cycle.                                                                       |
| K (6)<br>K (6)     | P(1)<br>P(2) | 1111<br>1111                            | 1111<br>1111         | 0001<br>0001              | 1010<br>1010                         |                                                                                           |
| K (7)<br>K (7)     | P(1)<br>P(2) | 1111<br>1111                            | 1111<br>1111         | 0001<br>0001              | 1010<br>1010                         |                                                                                           |
| K (8)<br>K (8)     | P(1)<br>P(2) | 0000<br>0000                            | 0001<br>0001         | 0001<br>0001              | 0010<br>0010                         | \$Data applied to data bus<br>\$(8-15). Data is code for<br>\$MOVE W DL.D2. so this is a  |
| K (9)<br>K (9)     | P(1)<br>P(2) | 0000                                    | 0001<br>0001         | 0001<br>1111              | 0010<br>1010                         | \$fetch.<br>\$End read cycle.                                                             |

# ADD.W D3.D5

ADD.W D3,D5 uses the data register direct addressing mode to sum the contents of data registers D3 and D5 and then store the result in D5. It is a single-word instruction requiring five clock cycles to execute its read cycle (prefetch). No address lines were monitored during its simulation. The results were:

|              |              | 15-12<br>DDDD<br>7654 | 11-8<br>DDDD<br>3210                    | 74<br>AULR<br>SDD/<br>SSW | 30<br>DFFF<br>TCCC<br>A210<br>C<br>K | (columns)<br>(signals)                                                                     |
|--------------|--------------|-----------------------|-----------------------------------------|---------------------------|--------------------------------------|--------------------------------------------------------------------------------------------|
| K(0)         | P(1)         | 1111                  | 1111                                    | 1111                      | 1010                                 | \$Begin read cycle.                                                                        |
| K(0)         | P(2)         | 1111                  | 1111                                    | 1111                      | 1010                                 |                                                                                            |
| K(1)<br>K(1) | P(1)<br>P(2) | 1111<br>1111          | $\begin{array}{c}1111\\1111\end{array}$ | 0001<br>0001              | 1010<br>1010                         |                                                                                            |
| K(2)         | P(1)         | 1111                  | 1111                                    | 0001                      | 1010                                 |                                                                                            |
| K(2)         | P(2)         | 1111                  | 1111                                    | 0001                      | 1010                                 |                                                                                            |
| K(3)<br>K(3) | P(1)<br>P(2) | 1000<br>1000          | 0101<br>0101                            | 0001<br>0001              | 0010<br>0010                         | <pre>\$Data applied to data bus<br/>\$(8-15). Data is code for<br/>\$MOVE.W D5.(A2).</pre> |
| K(4)         | P(1)         | 1000                  | 0101                                    | 0001                      | 0010                                 | \$End read cycle.                                                                          |
| K(4)         | P(2)         | 1000                  | 0101                                    | 1111                      | 1010                                 |                                                                                            |

The simulation and data logic analyzer results differed only on the data bus at phase two of clock cycle two. Here the logic analyzer caught the data bus transitioning to a valid data state while the simulation maintained high impedance.

#### BEO START

BEQ (Branch If Equal) is one of 14 variations of the MC68000's unconditional branch instructions. If the status register's zero condition code bit is set, then the program's execution will branch and continue at the location identified by the label "START"; otherwise, program execution continues with the instruction immediately following the BEQ instruction.

Hamby and Guillory tested the instruction "BEQ \$1004" where 1004 was the address of the first substantive

instruction of the test routine (MOVE.W D1,D3). However, the simulation uses the label "START" to identify the location of the instruction. The location of this instruction differed in the simulation (1000) because its test routine did not include as its first instruction "AND.W #\$DFFF,SR" to initialize the status register. This was accomplished in the ISP' initialization routine for this instruction model. This difference did not appear in the data being compared because the address lines were not monitored.

The simulation test routine examined processing in the case where the branch was taken as well as when it was not. The single-word instruction's execution time is dependent upon whether the branch is taken. If the branch condition is true, then the instruction required 12 clock cycles to complete its two read cycles; otherwise, it is completed in nine (single read cycle).

The CDL model contained two discrepancies. At phase two of clock cycle four, the program counter is incremented by two with the microstatement "PC <- PCadd2". This should not occur at this point because if the branch is taken the program counter will again be adjusted by the instruction's displacement at phase one of clock cycle nine (PC <-PCaddIR(0-7)). This could be properly handled if the compiler is aware that the program counter will be two words beyond the BEQ instruction at the time of the branch and computes the displacement accordingly. But to remain consistent with previous micro-operations, the program

VI-42

.

counter can best be incremented at phase two of clock cycle eight where it will be incremented only when the branch is not taken.

The microstatement "IR <- PFR" was added to those occurring at phase two of clock cycle 15. At this point, the branch has been taken and the instruction branched to has been fetched into the prefetch register. The contents of the prefetch register in turn must be placed in the instruction register so that the instruction can be decoded for execution. Alternately, since this is actually a fetch rather than a prefetch, instead of placing the contents of the external data buffer into the prefetch register with the statement "PFR <- EXDBUF" at phase one of clock cycle 15, its contents could be placed directly into the instruction register with the statement "IR <- EXDBUF" with equivalent results.

The only difference between the simulation and logic analyzer results again occurred when the logic analyzer caught the data bus transitioning to a valid data state at phase two of clock cycle two and 13. The complete results were:

Analyzer output (condition true, branch taken):

15-12 11-8 7--4 3--0 (columns)
DDDD DDDD AULR DFFF (signals)
7654 3210 SDD/ TCCC
SSW A210
C
K
K
(0) P(1) 1111 1111 1111 1010 \$Begin read cycle.
K(0) P(2)1111 1111 1111 1010 1111 1111 0001 1010 K(1) P(1)1111 1111 0001 1010 K(1) P(2) K(2) P(1)1111 1111 0001 1010 K(2) P(2) 1111 1111 0001 1010 K(3) P(1) 1101 0000 0001 0010 \$Data applied to data bus K(3) P(2) 1101 0000 0001 0010 \$(8-15). Data is code Sfor JMP (A0). K(4) P(1) 1101 0000 0001 0010 K(4) P(2) 1101 0000 1111 1010 \$End read cycle. 1111 1111 1111 1010 \$Data bus (8-15) K(9) P(1) 1111 1111 1111 1010 \$goes high. K(9) P(2) K(10) P(1) 1111 1111 1111 1010 K(10) P(2) 1111 1111 1111 1010 K(11) P(1)1111 1111 0001 1010 \$Begin read cycle. K(11) P(2) 1111 1111 0001 1010 K(12) P(1) 1111 1111 0001 1010 1111 1111 0001 1010 K(12) P(2)K(13) P(1) 1111 1111 0001 1010 K(13) P(2) 1111 1111 0001 1010 K(14) P(1) 0000 0001 0001 0010 \$Data applied to data bus K(14) P(2) 0000 0001 0001 0010 \$(8-15). Data is code for \$MOVE.W D1,D3, so this is a K(15) P(1) 0000 0001 0001 0010 \$fetch. K(15) P(2) 0000 0001 1111 1010 \$End read cycle. Analyzer output (condition false, branch not taken):

¢

15-12 11-8 7--4 3--0 (columns) DDDD DDDD AULR DFFF (signals) 7654 3210 SDD/ TCCC SSW A210 С K 1111 1111 1111 1010 \$Begin read cycle. K(0) P(1)K(0) P(2) 1111 1111 1111 1010 1111 1111 0001 1010 K(1) P(1)1111 1111 0001 1010 K(1) P(2) $K(2) \cdot P(1)$ 1111 1111 0001 1010 K(2) P(2) 1111 1111 0001 1010 K(3) P(1) 0000 0010 0001 0010 \$Data applied to data bus K(3) P(2) 0000 0010 0001 0010 \$(8-15). Data is code

VI-44

 $| \setminus |$ 

\$for MOVE.W D2,D3. K(4) P(1) 0000 0010 0001 0010 K(4) P(2) 0000 0010 1111 1010 \$End read cycle. K(5) P(1) 1111 1111 1010 \$Data bus (8-15) K(5) P(2) 1111 1111 1111 1010 \$qoes high. K(6) P(1) 1111 1111 1111 1010 1111 1111 1111 1010 K(6) P(2) K(7) P(1) 1111 1111 1111 1010 K(7) P(2) 1111 1111 1111 1010 K(8) P(1) 1111 1111 1111 1010 K(8) P(2) 1111 1111 1111 1010 \$End BEQ.

### BTST D1, (A1)

The BTST Dl,(Al) instruction will direct the MC68000 to retrieve a byte from the memory location specified by address register Al and then test the bit identified by the contents of data register Dl. If the selected bit is zero, then the status register's zero condition code bit (Z) is set; it is otherwise cleared. This single-word instruction required 10 clock cycles to execute its two read cycles. No address signals were monitored during the simulation. The results were:

15-12 11-8 7--4 3--0 (columns) DDDD DDDD AULR DFFF (signals) 7654 3210 SDD/ TCCC SSW A210 С K 1111 1111 1010 \$Begin read cycle.
1111 1111 1111 1010 K(0) P(1) K(0) P(2)K(1) P(1) 1111 1111 0001 1010 K(1) P(2) 1111 1111 0001 1010 1111 1111 0001 1010 K(2) P(1) 1111 1111 0001 1010 K(2) P(2)

0000 0010 0001 0010 \$Data applied to data bus K(3) P(1) 0000 0010 0001 0010 \$(8-15). Data is code K(3) P(2) Sfor MOVE.W D2,D3 so this 0000 0010 0001 0010 \$is a prefetch. K(4) P(1) 0000 0010 1111 1010 \$End read cycle. K(4) P(2)1111 1111 1111 1010 \$Begin read cycle. K(5) P(1) K(5) P(2) 1111 1111 1111 1001 K(6) P(1) 1111 1111 0101 1001 \$UDS' (6) not asserted K(6) P(2) 1111 1111 0101 1001 \$so only the low byte Sis read from memory. K(7) P(1) 1111 1111 0101 1001 K(7) P(2) 1111 1111 0101 1001 K(8) P(1) 0101 0101 0101 0001 \$Data applied to data bus 0101 0101 0101 0001 \$(8-15). Data is 55 hex. K(8) P(2) K(9) P(1) 0101 0101 0101 0001 K(9) P(2) 0101 0101 1111 1001 \$End read cycle.

The simulation and logic analyzer results differed on the data bus at phase two of clock cycle two. Again, the logic analyzer caught the bus transitioning to a valid data state while the simulation maintained high impedance.

#### Illegal Instruction Exception

The Illegal instruction (4AFC) allows the user to force an illegal instruction exception sequence. During this sequence, the status register is copied, the supervisor state entered, and the trace state turned off. A vector number is generated to refer to the illegal instruction vector. The current program counter (address of illegal instruction) and a copy of the status register are saved on the supervisor stack. Processing resumes at the address contained in the exception vector (11:66).

During the execution of a MC68000 instruction, the program counter points to the next instruction so that it is

in position for the current instruction's prefetch cycle. Therefore, during the model transformation process, the CDL microstatement "PC <- PCsub4" at phase two of clock cycle one was changed to "PC = PC - 2" in its ISP' counterpart in order to accurately locate the address of the illegal instruction.

For this instruction, address lines Al-A4 were monitored along with the lower eight data bus lines DO-D7 to facilitate data bus analysis. The simulation results were:

|                        | 19-16<br>AAAA<br>4321                   | 15-12<br>DDDD<br>7654                   | 11-8<br>DDDD<br>3210                       | 74<br>AULR<br>SDD/<br>SSW               | 30<br>DFFF<br>TCCC<br>A210<br>C<br>K | (columns)<br>(signals)                                                      |
|------------------------|-----------------------------------------|-----------------------------------------|--------------------------------------------|-----------------------------------------|--------------------------------------|-----------------------------------------------------------------------------|
| K(0) P(1)<br>K(0) P(2) | 1111<br>0110                            | 1111<br>1111                            | 1111<br>1111                               | 1111<br>1111                            | 1010<br>1010                         | <pre>\$K(0) thru K(4) is a \$read cycle just like \$the one described</pre> |
| K(1) P(1)<br>K(1) P(2) | 0110<br>0110                            | $\begin{array}{c}1111\\1111\end{array}$ | $\begin{array}{c}1111\\1111\end{array}$    | 0001<br>0001                            | 1010<br>1010                         | \$for the MOVE.W Dn,Dr<br>\$instruction.                                    |
| K(2) P(1)<br>K(2) P(2) | 0110<br>0110                            | $\begin{array}{c}1111\\1111\end{array}$ | $\begin{array}{c}1111\\1111\end{array}$    | 0001<br>0001                            | 1010<br>1010                         |                                                                             |
| K(3) P(1)<br>K(3) P(2) | 0110<br>0110                            | 0000<br>0000                            | 0001<br>0001                               | 0001<br>0001                            | 0010<br>0010                         | \$Data (8-15) is<br>\$code for<br>\$for MOVE N D1 D2                        |
| K(4) P(1)<br>K(4) P(2) | 0110<br>0110                            | 0000<br>0000                            | 0001<br>0001                               | 0001<br>1111                            | 0010<br>1010                         | \$End read cycle                                                            |
| K(5) P(1)<br>K(5) P(2) | 0110<br>1111                            | $\begin{array}{c}1111\\1111\end{array}$ | $\begin{array}{c}1111\\1111\end{array}$    | $\begin{array}{c}1111\\1111\end{array}$ | 1010<br>1010                         | \$Data Bus (8-15)<br>\$and address bus<br>\$(16-19) co bigb                 |
| K(6) P(1)<br>K(6) P(2) | 1111<br>1111                            | $\begin{array}{c}1111\\1111\end{array}$ | $\begin{array}{c}1111\\1111\end{array}$    | 1111<br>1111                            | 1010<br>1010                         | \$(16-19) go mign.                                                          |
| K(7) P(1)<br>K(7) P(2) | $\frac{1111}{1111}$                     | $\begin{array}{c}1111\\1111\end{array}$ | $\begin{array}{c} 1111\\ 1111 \end{array}$ | $\begin{array}{c}1111\\1111\end{array}$ | 1010<br>1010                         |                                                                             |
| K(8) P(1)<br>K(8) P(2) | $\begin{array}{c}1111\\1111\end{array}$ | $\begin{array}{c}1111\\1111\end{array}$ | $\begin{array}{c}1111\\1111\end{array}$    | $\frac{1111}{1111}$                     | 1010<br>1010                         |                                                                             |

K(9) P(1) 1111 1111 1111 1111 1010 \$Begin a write cycle K(9) P(2) 0010 1111 1111 1111 1101 \$just like the one \$described for the K(10) P(1)0010 1111 1111 0110 1101 \$MOVE.W Dn, (An) \$instruction, except \$for function codes Sand data. Function \$code (0-2) is Ssupervisor data Smode. K(10) P(2)0010 0000 1010 0110 1101 \$Data (8-15) is low Sword of the PC. 0000 1010 0000 1101 K(11) P(1) 0010 0010 K(11) P(2)0000 1010 0000 1101 0000 1010 0000 1101 K(12) P(1) 0010 K(11) P(2)0010 0000 1010 0000 1101 K(12) P(1) 0010 0000 1010 0000 0101 K(12) P(2) 0010 0000 1010 0000 0101 K(13) P(1) 0010 0000 1010 0000 0101 K(13) P(2) 0010 0000 1010 1110 1101 \$End Write Cycle. K(14) P(1)1111 0000 1010 1111 1101 \$Begin write cycle K(14) P(2) 0000 1111 1111 1111 1101 \$just like preceding Sone except for data. K(15) P(1) 0000 1111 1111 0110 1101 K(15) P(2) 0000 0000 0100 0110 1101 \$Data (8-15) is SR Scontents. 0100 0000 1101 K(16) P(1) 0000 0000 0000 0100 0000 1101 K(16) P(2) 0000 0100 0000 1101 K(17) P(1)0000 0000 0100 0000 1101 K(16) P(2) 0000 0000 0000 0100 0000 0101 K(17) P(1) 0000 0000 0100 0000 0101 K(17) P(2)0000 0000 0000 0100 0000 0101 K(18) P(1) K(18) P(2) 0000 0000 0100 1110 1101 \$End write cycle. K(19) P(1) 1111 0000 0100 1111 1101 \$Begin write cycle K(19) P(2) 0001 1111 1111 1111 1101 \$just like preceding Sone except for data. K(20) P(1) 0001 1111 1111 0110 1101 0000 0110 1101 \$Data (8-15) is high K(20) P(2) 0001 0000 Sword of PC. K(21) P(1) 0001 0000 0000 0000 1101 0000 0000 1101 K(21) P(2) 0001 0000 K(22) P(1) 0001 0000 0000 0000 1101 K(21) P(2) 0001 0000 0000 0000 1101 K(22) P(1) 0001 0000 0000 0000 0101

VI-48

.

| K(22)            | P(2)         | 0001         | 0000                                    | 0000                                    | 0000         | 0101         |                                                                              |
|------------------|--------------|--------------|-----------------------------------------|-----------------------------------------|--------------|--------------|------------------------------------------------------------------------------|
| K(23)<br>K(23)   | P(1)<br>P(2) | 0001<br>0001 | 0000                                    | 0000                                    | 0000<br>1110 | 0101<br>1101 | \$End write cycle.                                                           |
| K(24)<br>K(24)   | P(1)<br>P(2) | 1111<br>1000 | 0000                                    | 0000<br>1111                            | 1111<br>1111 | 1101<br>1101 | \$Begin read cycle<br>\$just like above                                      |
| K(25)<br>K(25)   | P(1)<br>P(2) | 1000<br>1000 | 1111<br>1111                            | 1111<br>1111                            | 0001<br>0001 | 1101<br>1101 | Sexcept data and<br>\$function codes.                                        |
| K(26)<br>K(26)   | P(1)<br>P(2) | 1000<br>1000 | 1111<br>1111                            | 1111<br>1111                            | 0001<br>0001 | 1101<br>1101 |                                                                              |
| K(27)<br>K(27)   | P(1)<br>P(2) | 1000<br>1000 | 0000                                    | 0000                                    | 0001<br>0001 | 0101<br>0101 | <pre>\$Data (8-15) is high \$word of the address</pre>                       |
| K(28)<br>K(28)   | P(1)<br>P(2) | 1000<br>1000 | 0000                                    | 0000                                    | 0001<br>1111 | 0101<br>1101 | Sof the exception<br>Shandler routine.<br>SEnd read cycle.                   |
| K(29)<br>K(29)   | P(1)<br>P(2) | 1111<br>1001 | 1111<br>1111                            | 1111<br>1111                            | 1111<br>1111 | 1101<br>1101 | \$Begin read cycle<br>\$just like                                            |
| K(30)<br>K(30)   | P(1)<br>P(2) | 1001<br>1001 | $\begin{array}{c}1111\\1111\end{array}$ | 1111<br>1111                            | 0001<br>0001 | 1101<br>1101 | spreceding one<br>Sexcept for data.                                          |
| K(31)<br>K(31)   | P(1)<br>P(2) | 1001<br>1001 | 1111<br>1111                            | 1111<br>1111                            | 0001<br>0001 | 1101<br>1101 |                                                                              |
| K(32)<br>K(32)   | P(1)<br>P(2) | 1001<br>1001 | 0000<br>0000                            | 0010<br>0010                            | 0001<br>0001 | 0101<br>0101 | <pre>\$Data (8-15) is low \$word of address of</pre>                         |
| K (33)<br>K (33) | P(1)<br>P(2) | 1001<br>1001 | 0000                                    | 0010<br>0010                            | 0001<br>1111 | 0101<br>1101 | Sexception handler<br>\$routine.<br>\$End read cycle.                        |
| K(34)<br>K(34)   | P(1)<br>P(2) | 1001<br>0001 | $\frac{1111}{1111}$                     | 1111<br>1111                            | 1111<br>1111 | 1101<br>1110 | <pre>\$K(34) thru K(38) is<br/>\$a read cycle just<br/>\$libb mageding</pre> |
| K(35)            | P(1)         | 0001         | 1111                                    | 1111                                    | 0001         | 1110         | Slike preceding one<br>Sexcept data and                                      |
| K(35)            | P(2)         | 0001         | 1111                                    | 1111                                    | 0001         | 1110         | SFunction codes.<br>SFunction code (0-2)                                     |
| K (36)<br>K (36) | P(1)<br>P(2) | 0001<br>0001 | 1111<br>1111                            | $\begin{array}{c}1111\\1111\end{array}$ | 0001<br>0001 | 1110<br>1110 | \$mode.                                                                      |
| K(37)<br>K(37)   | P(1)<br>P(2) | 0001<br>0001 | 0111<br>0111                            | 0011<br>0011                            | 0001<br>0001 | 0110<br>0110 | \$Data (8-15) is<br>\$return from                                            |
| K(38)            | P(1)         | 0001         | 0111                                    | 0011                                    | 0001         | 0110         | Sexception used as<br>Sexception handler                                     |
| K(38)            | P(2)         | 0001         | 0111                                    | 0011                                    | 0001         | 0110         | SEnd read cycle.                                                             |
| K (39)<br>K (39) | P(1)<br>P(2) | 1111<br>1111 | 1111<br>1111                            | 1111<br>1111                            | 1111<br>1111 | 1110<br>1110 | \$Data bus (8-15)<br>\$and address bus<br>\$go high.                         |

## K(40) P(1) 1111 1111 1111 1110 K(40) P(2) 1111 1111 1111 1110 \$End exception \$processing

Per the introductory discussion regarding the high impedance state of the address bus, at phase one of any new cycle, differences occur on ABUS whenever it is changing to the high impedance state. These take place at phase one of clock cycles 5, 14, 19, 24, 29, 34, and 39. Contrary to the earlier discussion regarding the high impedance state of the data bus, there are no differences on the data bus at phase one of those cycles that follow a write cycle. The logic analyzer's inability to capture its true state was anticipated and the instruction was modeled so that the data bus appears to return to the high impedance state during phase two.

Because the contents of the system stack pointer is repeatedly decremented and placed on the address bus during this sequence, its initial contents should be known in order to accurately describe the value on the data bus at all times. The ECB initializes the system stack pointer (SYSTACK) with the value 0786.

#### Address Error Exception

An address exeception sequence is initiated whenever the 68000 attempts to fetch a word or longword operand from an odd address. Whenever this occurs, the current bus cycle is aborted, the processor terminates current processing and begins a 60-clock cycle exception sequence that includes four read and seven write cycles.

The odd address error was generated by attempting to move a word from data register Dl to an odd memory location with the instruction "MOVE.W Dl,(Al)" (Al was initialized to 2001). The address bus is not monitored during the execution of this instruction. The simulation results were:

15-12 11-8 7--4 3--0 (columns) DDDD DDDD AULR DFFF (signals) 7654 3210 SDD/ TCCC SSW A210 C K 1111 1111 1111 1010 \$Begin read cycle. K(0) P(1) K(0) P(2)1111 1111 1111 1010 1111 1111 0001 1010 K(1) P(1)1111 1111 0001 1010 K(1) P(2) K(2) P(1)1111 1111 0001 1010 1111 1111 0001 1010 K(2) P(2)K(3) P(1) 0111 0001 0001 0010 \$Data applied to data bus 0111 0001 0001 0010 \$(8-15). Data is code for K(3) P(2) \$NOP, so this is a 0111 0001 0001 0010 \$prefetch. K(4) P(1) K(4) P(2) 0111 0001 1111 1010 \$End read cycle. 1111 1111 1111 1010 \$Begin a write cycle. K(5) P(1) K(5) P(2) 1111 1111 1111 1001 K(6) P(1) 1111 1111 0110 1001 0101 0101 0110 1001 \$Data put on data bus K(6) P(2) \$(8-15). data is 55 hex, K(7) P(1) 0101 0101 0000 1001 \$data being moved. K(7) P(2) 0101 0101 0000 1001 0101 0101 0000 1001 K(8) P(1) K(8) P(2) 0101 0101 1110 1001 K(0) P(1) 0101 0101 1111 1001 \$Write cycle terminated K(0) P(2)1111 1111 1111 1001 \$because of address error. \$Data bus (8-15) goes K(1) P(1) 1111 1111 1111 1001 \$high. K(1) P(2)1111 1111 1111 1001 1111 1111 1111 1001 K(2) P(1)1111 1111 1111 1001 K(2) P(2)

K(3) P(1) 1111 1111 1111 1001 K(3) P(2) 1111 1111 1111 1001 1111 1111 1111 1001 K(4) P(1)K(4) P(2)1111 1111 1111 1001 K(5) P(1)1111 1111 1111 1001 K(5) P(2)1111 1111 1111 1001 1111 1111 1111 1001 K(6) P(1) K(6) P(2) 1111 1111 1111 1001 K(7) P(1)1111 1111 1111 1001 K(7) P(2) 1111 1111 1111 1001 K(8) P(1) 1111 1111 1111 1001 \$Begin write cycle K(8) P(2) 1111 1111 1111 1101 \$Function codes (0-2) \$change to supervisor K(9) P(1) 1111 1111 0110 1101 \$data mode. K(9) P(2) 0000 1000 0110 1101 \$Data put on data bus \$(8-15). Data is low K(10) P(1) 0000 1000 0000 1101 \$word of PC. K(10) P(2)0000 1000 0000 1101 K(11) P(1) 0000 1000 0000 1101 K(10) P(2) 0000 1000 0000 1101 0000 1000 0000 0101 K(11) P(1) K(11) P(2) 0000 1000 0000 0101 K(12) P(1) 0000 1000 0000 0101 K(12) P(2) 0000 1000 1110 1101 \$End write cycle. 0000 1000 1111 1101 \$Begin write cycle. K(13) P(1) K(13) P(2) 1111 1111 1111 1101 1111 1111 0110 1101 K(14) P(1) K(14) P(2)0000 0000 0110 1101 \$Data put on data bus \$(8-15). Data is SR K(15) P(1) 0000 0000 0000 1101 \$contents. 0000 0000 0000 1101 K(15) P(2) K(16) P(1)0000 0000 0000 1101 K(15) P(2) 0000 0000 0000 1101 K(16) P(1) 0000 0000 0000 0101 K(16) P(2)0000 0000 0000 0101 0000 0000 0000 0101 K(17) P(1)K(17) P(2) 0000 0000 1110 1101 \$End write cycle. K(18) P(1) 0000 0000 1111 1101 \$Begin write cycle. 1111 1111 1111 1101 K(18) P(2)

K(19) P(1) 1111 1111 0110 1101 0000 0000 0110 1101 \$Data put on data bus K(19) P(2) \$(8-15). Data is high 0000 0000 0000 1101 Sword of PC. K(20) P(1) K(20) P(2) 0000 0000 0000 1101 K(21) P(1) 0000 0000 0000 1101 K(20) P(2) 0000 0000 0000 1101 0000 0000 0000 0101 K(21) P(1) K(21) P(2)0000 0000 0000 0101 K(22) P(1) 0000 0000 0000 0101 K(22) P(2) 0000 0000 1110 1101 \$End write cycle. 0000 0000 1111 1101 \$Begin write cycle K(23) P(1) K(23) P(2) 1111 1111 1111 1101 K(24) P(1) 1111 1111 0110 1101 K(24) P(2) 1000 0001 0110 1101 \$Data put on data bus \$(8-15). Data is code 1000 0001 0000 1101 \$for instruction being K(25) P(1) K(25) P(2) 1000 0001 0000 1101 \$executed when interrupt \$occurred. K(26) P(1) 1000 0001 0000 1101 K(25) P(2) 1000 0001 0000 1101 K(26) P(1) 1000 0001 0000 0101 K(26) P(2) 1000 0001 0000 0101 1000 0001 0000 0101 K(27) P(1) K(27) P(2) 1000 0001 1110 1101 \$End write cycle. K(28) P(1) 1000 0001 1111 1010 \$Begin a write cycle. K(28) P(2) 1111 1111 1111 1101 K(29) P(1) 1111 1111 0110 1101 K(29) P(2) 0000 0001 0110 1101 \$Data put on data bus \$(8-15). Data is low K(30) P(1) 0000 0001 0000 1101 \$word of memory being K(30) P(2) 0000 0001 0000 1101 \$used when interrupt Soccurred. 0000 0001 0000 1101 K(31) P(1) K(30) P(2) 0000 0001 0000 1101 0000 0001 0000 0101 K(31) P(1) K(31) P(2) 0000 0001 0000 0101 0000 0001 0000 0101 K(32) P(1) 0000 0001 1110 1101 \$End Write Cycle. K(32) P(2) 0000 0001 1111 1101 \$Begin write cycle. K(33) P(1) K(33) P(2) 1111 1111 1111 1101 K(34) P(1) 1111 1111 0110 1101

•

0000 0001 0110 1101 \$Data put on data bus K(34) P(2)\$(8-15). Data is cycle K(35) P(1) 0000 0001 0000 1101 \$type (R/W) and function K(35) P(2) 0000 0001 0000 1101 \$codes when interrupt Soccurred. K(36) P(1) 0000 0001 0000 1101 K(35) P(2) 0000 0001 0000 1101 0000 0001 0000 0101 K(36) P(1) 0000 0001 0000 0101 K(36) P(2) 0000 0001 0000 0101 K(37) P(1) K(37) P(2) 0000 0001 1110 1101 \$End write cycle. 0000 0001 1111 1101 \$Begin write cycle. K(38) P(1) K(38) P(2) 1111 1111 1111 1101 1111 1111 0110 1101 K(39) P(1) K(39) P(2) 0000 0000 0110 1101 \$Data put on data bus \$(8-15). Data is high 0000 0000 0000 1101 \$word of memory being K(40) P(1)K(40) P(2) 0000 0000 0000 1101 \$used when interrupt Soccurred. 0000 0000 0000 1101 K(41) P(1) K(40) P(2) 0000 0000 0000 1101 0000 0000 0000 0101 K(41) P(1) K(41) P(2) 0000 0000 0000 0101 K(42) P(1) 0000 0000 0000 0101 K(42) P(2) 0000 0000 1110 1101 \$End write cycle. 0000 0000 1111 1101 \$Begin read cycle. K(43) P(1) K(43) P(2) 1111 1111 1111 1101 1111 1111 0001 1101 K(44) P(1)K(44) P(2)1111 1111 0001 1101 1111 1111 0001 1101 K(45) P(1), 1111 1111 0001 1101 K(45) P(2) K(46) P(1) 0000 0000 0001 0101 \$Data applied to data bus K(46) P(2) 0000 0000 0001 0101 \$(8-15). Data is high \$word of address of 0000 0000 0001 0101 Sexception handler routine. K(47) P(1) K(47) P(2) 0000 0000 1111 1101 \$End read cycle. 1111 1111 1111 1101 \$Begin read cycle. K(48) P(1) K(48) P(2) 1111 1111 1111 1101 1111 1111 0001 1101 K(49) P(1) 1111 1111 0001 1101 K(49) P(2) K(50) P(1) 1111 1111 0001 1101 K(50) P(2) 1111 1111 0001 1101

. .

K(51) P(1) 0100 0000 0001 0101 \$Data applied to data bus 0100 0000 0001 0101 \$(8-15). Data is low K(51) P(2) \$word of address of 0100 0000 0001 0101 Sexception handler routine. K(52) P(1) 0100 0000 1111 1101 \$End read cycle. K(52) P(2) K(53) P(1) 1111 1111 1111 1101 \$Begin read cycle. K(53) P(2) 1111 1111 1111 1110 \$Function codes (0-2) \$change to supervisor 1111 1111 0001 1110 \$program mode. K(54) P(1) K(54) P(2) 1111 1111 0001 1110 K(55) P(1) 1111 1111 0001 1110 1111 1111 0001 1110 K(55) P(2) 1000 1111 0001 0110 \$Data applied to data bus K(56) P(1) 1000 1111 0001 0110 \$(8-15). Data is code for K(56) P(2) \$first instruction of 1000 1111 0001 0110 Sexception handler routine. K(57) P(1) K(57) P(2) 1000 1111 1111 1110 \$End read cycle. 1111 1111 1111 1110 \$Data bus goes high. K(58) P(1) K(58) P(2)1111 1111 1111 1110 K(59) P(1) 1111 1111 1111 1110 1111 1111 1111 1110 \$End exception K(59) P(2) Sprocessing

N.

The initial difference between the simulation and logic analyzer results begins at phase two of the second clock cycle 15 (wait state) and continues through phase two of clock cycle 17. During this time period, the logic analyzer data shows the data bus at state "0001 0000" while the simulation indicates state "0000 0000". This is the write cycle that saves the contents of the status register at the time the illegal address reference was made. The state represented by the logic analyzer data is inaccurate.

The state of the status register at the time of the address error was zero because only the supervisor mode bit -- (bit 13) was addressed during the test routine, and it was set to zero by the "AND.W #\$DFFF,SR" instruction to place

the 68000 in the user mode. The four condition code bits, interrupt mask, or trace bit were not altered from their original low states. The SR is placed on the data bus at phase two of clock cycle 14 and should remain there for the duration of the write cycle (phase two of clock cycle 17). This information, along with the fact that the logic analyzer result could not be duplicated, suggests that this is a consistent typing error.

Another difference begins at phase two of clock cycle 34 and continues through phase 2 of clock cycle 37. Here the logic analyzer data depicts the data bus at state "1000 0001" while the simulation indicates "0000 0001". This data represents the type of memory access that was attempted at the time of the exception: information such as whether it was a read or write, whether the processor was processing an instruction or not, and the state of the function code outputs when the address error occured (11:67). The format of the access type is depicted in Figure VI-4.

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | _5 | 4    | 3    | 2    | 1       | 0   |
|----|----|----|----|----|----|---|---|---|---|----|------|------|------|---------|-----|
|    |    |    |    |    |    |   |   |   |   |    |      |      |      |         |     |
|    |    |    |    |    |    |   |   |   |   |    | F./1 | ¶1/1 | H+C2 | 219°C - | 150 |

Figure VI-4. Memory Access Type (11:68)

Neither Figure VI-4 nor any of the other available documentation indicate that bit seven is used by the 68000. Because this analyzer output was duplicated, it appears this

portion of the address error exeception cannot be accurately modeled without additional documentation.

The format of the memory access type also revealed an error in the CDL model for this instruction. At phase one of clock cycle eight, the microstatement "ACTYPE(3) <-EXCEPT" was changed to "ACTYPE<3> = 10" in the ISP' version. This bit indicates whether the 68000 was processing an instruction at the time of the exception or not (instruction = 0, not = 1) (11:68). Because EXCEPT was in a high state, assigning it to ACTYPE(3) would incorrectly indicate that the 68000 was not processing an instruction at the time of the exception.

At phase two of clock cycle 23, this instruction's CDL model contains the microstatement "IDBUS <- IR". The objective is to save the instruction causing the address exception (ll:67). However, since the instruction that erred was placed in a temporary instruction register at phase two of clock cycle seven with the microstatement "IRTEMP <- IR", and then IR was reused at phase two of clock cycle eight, the saving microstatement will not achieve the desired results. It was instead replaced with the microstatement "IDBUS = IRTEMP" in the ISP' version.

The simulation's data bus also differs from the logic analyzer's results at phase two of clock cycles 45 and 55. The simulation indicates a high impedance state (1111 1111) and logic analyzer data shows "1011 1111". Similar to the simulation of the MOVE.W D1, 04(A1) instruction, the logic

analyzer appears to have caught the data bus in transition because the differences occur when the memory is placing data on the bus during read cycles. The ISP' model for this instruction also anticipated the delay in showing the data bus at the high impedance state following write cycles.

المراجع والمراجع الإلا

VII. Conclusions and Recommendations

# Introduction

This thesis was a follow-on effort to another project whose objective was to develop a functional model of the Motorola MC68000 that was capable of being simulated. The model was to be constructed through signal analysis supported only by technical data normally provided to a retail purchaser of the system (8:I-6,7). The natural objective of this succeeding project was to simulate the models that were developed using that approach, analyze the results, and then draw conclusions regarding its viability based on the accuracy and completeness of the models. This chapter will present the conclusions resulting from this study, as well as suggest further areas of research that may broaden the conclusions reached regarding this innovative method of microprocessor modeling and simulation.

# <u>Conclusions</u>

The completeness and accuracy of the models developed by Hamby and Guillory demonstrate that the MC68000 can be modeled at the functional level through signal analysis supported by technical literature available to the public. The state of the MC68000 was accurately depicted at each clock cycle when executing a variety of instructions and exception sequences. Only the dynamics of the address and data buses during transitional periods prevent the state of each of the MC68000's signals from being totally deterministic for every clock cycle. Even when the state of the bus is otherwise deterministic, the lack of sophistication of the monitoring equipment sometimes prevented it from being accurately captured. But because these indeterminate states occur at cycles which are of no functional consequence to correct processor operation, they can be ignored in terms of their impact on the accuracy of the model.

Based on the mix of instructions, exceptions, and addressing modes modeled, it appears that there would be no difficulty in modeling the complete set of MC68000 instructions and exception processing states. This conclusion can reasonably be extended to include other processors whose architectural complexity does not exceed the MC68000's. However, no definite conclusions can be reached regarding the effectiveness of this modeling approach on other processors with more complex architectures or sophisticated implementation techniques. Even some architectures less sophisticated than the MC68000 may prove more troublesome to model with this approach. For example, the 16-bit Intel 8088 multiplexes a subset of its 20 address lines to support eight-bit data transfers. This may hamper this modeling approach by making the process of capturing, distinguishing, and interpreting the address and data signals much more difficult.

Some of the more sophisticated 32-bit architectures

VII-2

employing extensive parallelism and pipelining may prove to be even much more challenging. A good example is the latest version of the MC68000 family of microprocessors, the MC68020. The MC68020 maintains a 256-byte-on-chip instruction cache. This capability removes the instruction stream from the data bus making instruction identification more difficult as they are executing. This cache implementation also allows simultaneous instruction and data accesses to occur hiding the execution of some microinstructions from the observer. The technical data necessary to accurately model the processor's management of the instruction cache may also be difficult to obtain. The algorithms employed to initialize the cache, update both it and main memory during writes, and reload the cache during misses would be difficult to discern from signal analysis alone. Further increasing the difficulty of employing this modeling approach on the MC68020 is the fact that the instruction pipeline has been increased from two to three words thereby allowing three instructions to concurrently undergo the process of decoding and execution.

Another processor with an imposing architecture that may be extremely difficult to model with this approach is Intel's iAPX 432. The iAPX 432 is actually a three-chip set with each packaged in a 64-pin quad in-line package (QUIP). Two of the chips combine to form the General Data Processor (GDP): the iAPX 43201 (instruction decode unit) and the iAPX 43202 (instruction execution unit). These two chips

communicate across a microinstruction bus to fetch, decode, and execute program instructions. A third chip, the iAPX 43203 interface processor coordinates all I/O between peripherals and memory. An attached processor such as the Intel 8086 is used in conjunction with the iAPX 43203 to form an I/O processor unit for the iAPX 432 system. The iAPX 43203 communicates with the attached processor via a subsystem bus and with the GDP using a "packet" bus. The packet bus uses data packets that vary from one to sixteen bytes in length to provide communications between the GDP, memory, and interface processor. The number of chips, buses, and signals comprising the iAPX 432 system, coupled with the packeting of bus information would certainly make the task of modeling the iAPX using the approach under study very difficult, if not impossible.

The complexity of the instruction set also becomes an issue when considering a high-level-language architecture such as the iAPX 432. The iAPX 432 has 230 instructions with lengths that vary from six to 344 bits. Each of the instruction fields are also bit-variable and can encase up to six operands. Instructions such as "CREATE-DATA-SEGMENT" may consist of hundreds of microoperations requiring a significant number of clock cycles to execute. The identification of both macro and microinstructions embedded in packets transmitted over multiple buses for an extended number of clock cycles will require extensive and detailed technical data supported by several sophisticated monitoring

VII-4

devices.

A point that should be made is that even though it may be extremely difficult to gather the data necessary to model a system such as the iAPX 432 using this approach, there certainly would be no difficulty in coding and simulating the model using N.mPc. One of N.mPc's strong suits is its ability to describe and simulate networked multiple microprocessor systems such as the iAPX 432. Each of the iAPX 432's three processors, its supporting memory, and the attached processor could be independently modeled and linked through a description of their multiple connecting bus structures to form a simulatable system from which operational performance data could be gathered.

## Recommendations

1. Model other microprocessors using this approach to determine which architectural implementations lend themselves to this modeling method. Architectural designs or implementation techniques forming barriers to this approach could then be identified and documented. An upper bound in terms of architectural complexity that can be modeled with confidence using this approach could be established. Some candidates in order of their increasing complexity are the aforementioned microprocessors; the Intel 8088, the MC68020, and the Intel iAPX 432.

2. Develop a generalized and optimized model of the MC68000 with N.mPc. By conforming with the CDL originals, the current ISP' models became too primitive and

VII-5

specialized. Each instruction was independently modeled to process specific operands for a particular addressing mode. Each contained its own internal memory and timing signals. Not only does such an arrangement not represent the real world environment, but to model the MC68000's complete set of instructions in all of their addressing modes would have required over 1000 models averaging 50 kbytes in length each. This number would escalate greatly if each instruction were not assumed to receive a generalized operand set. A complete model of the MC68000 that consolidates instruction models of this type is obviously out of the question. A more practical approach is to discard the previous model structure and adopt a more general composition that will enable the researcher to take advantage of the capabilities of a nonprecedural language such as ISP' and its host system, N.mPc.

Generalized routines to model multiple instructions in each of their addressing modes and accept any of their legitimate operands could easily be developed to minimize the model size while maximizing its ability to completely describe the MC68000. For example, the fourteen models developed during this project to represent variations of the "MOVE" instruction could be consolidated into a single procedure that received its operands, the data size, and its addressing modes as parameters. It would itself make calls to general lower-level routines as necessary to accomplish the microinstructions associated with a particular variation. The memory and two-phase clocking signals could be modeled as independent system entities that communicate with the MC68000 over a system bus. Such a representation would afford an opportunity to model, simulate, and analyze the MC68000 at a level of detail not heretofore achieved. VIII. Analysis of Time Spent on Project

#### Introduction

One of the requirements of this thesis was to maintain a detailed log of all time spent on the project. This chapter presents an analysis of that time log.

#### Summary of Time

Project time was spent as follows:

- 1. Background Research and Project Preparation 18 hrs
  - Identifying Research Objectives
  - Performing Literature Search
  - Reviewing Texts and Articles
  - Studying Predecessor Thesis
  - Formulating Research Approach
- 2. N.mPc Installation and Familiarization 91 hrs
  - Installing, Configuring, and Testing System
  - Generating System Documentation
  - N.mPc Familiarization
- 3. MC68000, ECB, and Logic Analyzer Familiarization 25 hrs
  - Reviewing Texts, Articles, and Technical
    - Documentation
  - Programming ECB
  - Operating Logic Analyzer
- 4. CDL-to-ISP' Model Transformations
  - CDL and ISP' Familiarization
  - Formulating Transformation Methodology

VIII-1

58 hrs

- Coding ISP' Models

5. Simulate Models

- Develop Simulation Strategy
- Building Individual Instruction Simulations
- Running Simulations
- Testing and Debugging Simulations
- Generating Simulation Hardcopies
- 6. Simulation Analysis
  - Reviewing Simulation Data
  - Reviewing Logic Analyzer Data
  - Re-examining MC68000 Operation
  - Correcting Model Discrepancies
- 7. Thesis Preparation
  - Writing
  - Typing
  - Editing
  - Printing

Hamby and Guillory speculated in their thesis that it would require a team of two people approximately six months to test and model the entire MC68000 processor using this approach (8:VII-2,3). I further recommend that one of the team members be "software-oriented" to facilitate the development of a generalized model as recommended in Chapter VII. Such a model will require someone experienced in the areas of software engineering, modular programming, etc. Accepting their estimate, this team configuration will allow the development and simulation of a generalized and

## VIII-2

418 hrs

60 hrs

42 hrs



١

. .







•

.

# <u>Bibliography</u>

1. ADI-814-I. MC68000 Advance Information. Austin, Texas: Motorola Semiconductor Products Inc., 1982.

2. Barbacci, Mario R. "A Comparison of Register Transfer Languages for Describing Computers and Digital Systems," <u>IEEE</u> <u>Transactions on Computers, C-24</u> (2): 137-148 (February 1975).

3. Bryce, Heather. "Microprogramming Makes the MC68000 a Processor Ready for the Future," <u>Electronic Design</u> (October 25, 1979).

4. Chu, Yaohan. <u>Computer Organization and Microprogramming</u>. Englewood Cliffs, N.J.: Prentice-Hall Inc., 1972.

5. Drongowski, Paul J. "Functional Simulation with the N.mPc System," <u>VLSI DESIGN</u>: 76-77 (Jan 1984).

6. Drongowski, Paul J. et al. "A Guide for Writing N.mPc Hardware Models." Department of Computer Engineering and Science, Case Western Reserve University, Cleveland OH, January 1984.

7. Fong, James Y. O. "Microprocessor Modeling for Logic Simulation," <u>Proceedings of the IEEE 1981 International Test</u> <u>Conference</u>: 458-460 (October 1981).

8. Hamby, James R. and Galen J. Guillory. <u>Architectural</u> <u>Analysis and Modeling of a Motorola MC68000 Microprocessor</u>. MS Thesis, GE/EE/83D-23. School of Engineering, Air Force Institute of Technology (AU), Wright Patterson AFB, Ohio, December 1983.

9. Hewitt, Donald C. Jr. <u>The Runtime Environment for N.mPc</u>, <u>An Adaptable Software System to Support the Development of</u> <u>Microprocessor-Based Systems</u>. MS Thesis CES-79-7. Department of Computer Engineering and Science, Case Western Reserve University, Cleveland OH, January 1979.

10. MC68000UM[AD2]. MC68000 16-Bit Microprocessor User's Manual (Second Edition). N.J.: Prentice-Hall, 1982.

11. MC68000UM[AD3]. MC68000 16-Bit Microprocessor User's Manual (Third Edition). N.J.: Prentice-Hall, 1982.

12. NP-355-R1. MC68000 Product Review. Austin, Texas: Motorola Semiconductor Products Inc., 1982.

13. Ordy, Greg M. N.mPc: Ecologist User's Manual. Department of Computer Engineering and Science, Case Western Reserve University, Cleveland OH, March 1979.

14. Ordy, Greg M. N.mPc: <u>Runtime User's Manual</u>. Department of Computer Engineering and Science, Case Western Reserve University, Cleveland OH, March 1979. 15. RADC-TR-81-343. <u>Product Evaluation Report of the Motorola</u> <u>MC68000</u>. Griffis AFB, N.Y.: Rome Air Development Center, Nov 1981.

16. Rogers, Lawrence R. and Greg M. Ordy. <u>The Metamicro</u> <u>User's Manual, Version 3.1</u>. Department of Computer Engineering and Science, Case Western Reserve University, Cleveland OH, March 1980.

17. Rogers, Lawrence R. <u>The Linking/Loader User's Manual</u>, <u>Version 1.1</u>. Department of Computer Engineering and Science, Case Western Reserve University, Cleveland OH, March 1980.

18. Rose, Charles W. et al. "N.mPc: A Study in University-Industry Technology Transfer," <u>IEEE Design and</u> <u>Test</u>: 44-56 (Feb 1984).

19. Shah, Samir S. <u>An Assessment of N.mPc for 16-Bit</u> <u>Systems</u>. MS Thesis CES-80-10. Department of Computer Engineering and Science, Case Western Reserve University, Cleveland OH, August 1980.

20. Straubs, R. V. <u>ISP' User's Manual</u>. MS Thesis CES-78-8. Department of Computer Engineering and Science, Case Western Reserve University, Cleveland OH, August 1978.

21. Stritter, Edward and Tom Gunter. "A Microprocessor Architecture for a Changing World: The Motorola 68000," <u>Microsystems</u> (February 1979).

22. Titus, Christopher A. et al. <u>16-Bit Microprocessors</u>. Indianapolis: Howard W. Sams & Co., 1982.

23. Toong, Hoo-min D. and Amar Gupta. "An Architectural Comparison of Contemporary 16-Bit Microprocessors", <u>IEEE</u> <u>Transactions on Computers</u>, (May 1981).

| and the second secon |              |                                                                                                |                                                      | An                          | 411,11.1                                        | 02                 |  |  |  |
|-----------------------------------------------------------------------------------------------------------------|--------------|------------------------------------------------------------------------------------------------|------------------------------------------------------|-----------------------------|-------------------------------------------------|--------------------|--|--|--|
| UNITY CLASSIFICATION OF THIS PA                                                                                 | AGE          |                                                                                                |                                                      |                             |                                                 |                    |  |  |  |
|                                                                                                                 |              | REPORT DOCUM                                                                                   | ENTATION PAGE                                        | ABYINGS                     |                                                 |                    |  |  |  |
| UNCLASSIFIED                                                                                                    |              |                                                                                                |                                                      |                             |                                                 |                    |  |  |  |
| SECURITY CLASSIFICATION AUTH                                                                                    | ORITY        |                                                                                                | 3. DISTRIBUTION/A                                    | VAILABILITY OF              | REPORT                                          |                    |  |  |  |
| DECLASSIFICATION/DOWNGRADI                                                                                      | NG SCHED     | ULE                                                                                            | Approved f<br>distributi                             | or public<br>on unlimi      | release;<br>ted.                                | ۲                  |  |  |  |
| PERFORMING ORGANIZATION REP                                                                                     | ORT NUME     | IER(S)                                                                                         | 5. MONITORING OR                                     | GANIZATION REI              | PORT NUMBER(S)                                  | C                  |  |  |  |
| AFIT/GCS/ENG/84-D-2                                                                                             |              |                                                                                                |                                                      |                             |                                                 |                    |  |  |  |
| NAME OF PERFORMING ORGANIZ                                                                                      | ATION        | Bb. OFFICE SYMBOL<br>(If applicable)                                                           | 74. NAME OF MONITORING ORGANIZATION                  |                             |                                                 |                    |  |  |  |
| School of Engineerin                                                                                            | ng           | AFIT/ENG                                                                                       | 1                                                    |                             |                                                 | • •                |  |  |  |
| ADDRESS (City, State and ZIP Code)                                                                              | e of T       | echnology                                                                                      | 76. ADDRESS (City, S                                 | State and ZIP Code          | )                                               | -                  |  |  |  |
| Wright-Patterson A                                                                                              | ·<br>FB, Oh  | 10 45433                                                                                       |                                                      |                             |                                                 |                    |  |  |  |
| NAME OF FUNDING/SPONSORING                                                                                      |              | BL. OFFICE SYMBOL                                                                              | 9. PROCUREMENT I                                     | NSTRUMENT IDE               | NTIFICATION NU                                  | MBER .             |  |  |  |
| AFSC/FTD                                                                                                        |              | TQTA                                                                                           |                                                      |                             |                                                 |                    |  |  |  |
| ADDRESS (City, State and ZIP Code)                                                                              |              |                                                                                                | 10. SOURCE OF FUN                                    | IDING NOS                   |                                                 |                    |  |  |  |
|                                                                                                                 |              |                                                                                                | PROGRAM<br>ELEMENT NO.                               | PROJECT<br>NO.              | TASK<br>NO.                                     | NO.                |  |  |  |
| PITLE (Include Security Classification                                                                          |              | 4                                                                                              |                                                      |                             |                                                 |                    |  |  |  |
| See Box 19                                                                                                      |              |                                                                                                |                                                      |                             |                                                 |                    |  |  |  |
| (harles A. Baxley                                                                                               | Jr., B       | .S., Capt, U                                                                                   | SAF                                                  |                             |                                                 |                    |  |  |  |
| MS Thesis                                                                                                       | 36. TIME CO  | TO                                                                                             | 14. DATE OF REPOR                                    | at (Yr., Mo., Day)<br>ember | 15. PAGE CO<br>1200                             | DUNT               |  |  |  |
| SUPPLEMENTARY NOTATION                                                                                          |              |                                                                                                | - <b>-</b>                                           |                             |                                                 |                    |  |  |  |
|                                                                                                                 |              |                                                                                                |                                                      |                             |                                                 |                    |  |  |  |
| COSATI CODES                                                                                                    | GR           | 18 SUBJECT TERMS (<br>Computer D                                                               | Continue on reverse if ne<br>Design Langua           | age (CDL),                  | y by block number<br>Instructi                  | on Set             |  |  |  |
| 09 02                                                                                                           |              | Processor (ISP'), N.mPc(Networked Microprocesson<br>Motorola MC68000, Microprocessor Modeling, |                                                      |                             |                                                 |                    |  |  |  |
| ABSTRACT (Cuntinue on reverse of n                                                                              | ecessary and | i identify by block numb                                                                       | eri                                                  |                             |                                                 |                    |  |  |  |
| Title: THE SIMULAT                                                                                              | TON AN       | ND ANALYSIS C                                                                                  | OF A RTL MODE                                        | EL OF THE                   | MOTOROLA                                        |                    |  |  |  |
| MC68000 MIC                                                                                                     | CROPROC      | ESSOR WITH N                                                                                   | l.mPc                                                |                             | ·                                               |                    |  |  |  |
| Thesis Chairman: F                                                                                              | rederi       | ick A. Zapka,                                                                                  | , Major, USA                                         | Repfored !                  | lor yubic releve:                               | IAW APR MALL       |  |  |  |
|                                                                                                                 |              |                                                                                                |                                                      | Dom for S<br>Air Force      | Research and Profes<br>Institute of Technologic | nional Development |  |  |  |
|                                                                                                                 |              |                                                                                                |                                                      | Wright-Pet                  | toree AFB OH 45                                 | 41                 |  |  |  |
|                                                                                                                 |              | ,                                                                                              | •                                                    |                             |                                                 |                    |  |  |  |
|                                                                                                                 |              |                                                                                                |                                                      |                             |                                                 |                    |  |  |  |
| ,                                                                                                               |              |                                                                                                |                                                      |                             |                                                 |                    |  |  |  |
| ,                                                                                                               |              |                                                                                                |                                                      |                             | ATION                                           |                    |  |  |  |
| G DISTRIBUTION/AVAILABILITY O                                                                                   | F AUSTRA     | 27                                                                                             | 21. ABSTRACT SEC                                     | URITY CLASSIFIC             |                                                 |                    |  |  |  |
| O DISTRIBUTION/AVAILABILITY O                                                                                   | F ABSTRAG    |                                                                                                | 21. ABSTRACT SEC<br>UNCLASSIF                        | TED                         |                                                 |                    |  |  |  |
| DISTRIBUTION/AVAILABILITY O                                                                                     | DE AUSTRAG   |                                                                                                | 21. ABSTRACT SEC<br>UNCLASSIF<br>22b TELEPHONE N<br> | URITY CLASSIFIC             | 226 OFFICE SYM                                  | BOL                |  |  |  |

É

#### UNCLASSIFIED

SECUTITY CLASSIFICATION OF THIS PAGE

- 18. Microprocessor Simulation, Microprocessor Analysis, Computer Architecture, Microcomputers, Computerized Simulation, Digital Simulation.
- 19. In a prior thesis project, a functional level model of portions of the Motorola MC68000 microprocessor was developed using signal analysis supported by limited technical data. Representative parts of the instruction set and exception processing structure were modeled with the Computer Design Language (CDL). In this follow-on effort, those CDL models are transformed into equivalent models using ISP', an enhanced vers on of the Instruction Set Processor (ISP) hardware design language. This language transformation enabled the models to be simulated using N.mPc, a VAX : 11/780-hosted software package developed specifically to support the design of digital systems. To evaluate the correctness of the of the models, the simulation results are analyzed against signal data gathered with the aid of a logic analyzer during the actual operation of the MC68000 when processing the modeled instructions. The accuracy and completeness of the examined models suggests that this functional approach to microprocessor modeling is a valid one.

