# THE DESIGN AND ANALYSIS OF INSTRUCTION SET PROCESSORS Mario R. Barbacci and Daniel P. Siewiorek # The Design and Analysis of Instruction Set Processors Mario R. Barbacci **Daniel P. Siewiorek** Carnegie-Mellon University McGraw-Hill Book Company New York St. Louis San Francisco Auckland Bogotá Hamburg Johannesburg London Madrid Mexico Montreal New Dehli Panama Paris São Paulo Singapore Sydney Tokyo Toronto #### The Design and Analysis of Instruction Set Processors Copyright © 1982 by McGraw-Hill, Inc. All rights reserved. Printed in the United States of America. Except as permitted under the United States Copyright Act of 1976, no part of this publication may be reproduced or distributed in any form or by any means, or stored in a data base or retrieval system, without prior written permission of the publisher. 234567890SMSM898765432 ISBN 0-07-057303-4 The editor was James E. Vastyan; the production supervisor was Joe Campanella. Semline, Inc., was printer and binder. #### Library of Congress Cataloging in Publication Data Barbacci, Mario R. The design and analysis of instruction set processors. (McGraw-Hill computer science series) Bibliography: p. Includes index. 1. Computer architecture. 2. ISP (Computer program language) I. Siewiorek, Daniel P. II. Title. III. Series. QA76.9.A73B37 621.3819'52 81-23620 ISBN 0-07-057303-4 AACR2 The Design and Analysis of Instruction Set Processors #### **McGraw-Hill Computer Science Series** Ahuja: DESIGN AND ANALYSIS OF COMPUTER COMMUNICATION NETWORKS Allen: ANATOMY OF LISP Barbacci and Siewiorek: THE DESIGN AND ANALYSIS OF INSTRUCTION SET PROCESSORS Bell and Newell: COMPUTER STRUCTURES: Readings and Examples Donovan: SYSTEMS PROGRAMMING Gear: COMPUTER ORGANIZATION AND PROGRAMMING GIVONE: INTRODUCTION TO SWITCHING CIRCUIT THEORY Goodmann and Hedetniemi: INTRODUCTION TO THE DESIGN AND ANALYSIS OF ALGORITHMS Hamacher, Vranesic, and Zaky: Computer organization Hamming: Introduction to applied numerical analysis Hayes: Computer architecture and organization Hellerman: Digital Computer system principles Hellerman and Confoy: Computer system performance Katzan: MICROPROGRAMMING PRIMER Keller: A FIRST COURSE IN COMPUTER PROGRAMMING USING PASCAL Liu: ELEMENTS OF DISCRETE MATHEMATICS Liu: INTRODUCTION TO COMBINATORIAL MATHEMATICS MacEwen: INTRODUCTION TO COMPUTER SYSTEMS: Using the PDP-11 and Pascal Madnick and Donovan: OPERATING SYSTEMS Manna: MATHEMATICAL THEORY OF COMPUTATION Newman and Sproull: PRINCIPLES OF INTERACTIVE COMPUTER GRAPHICS Nilsson: PROBLEM-SOLVING METHODS IN ARTIFICIAL INTELLIGENCE Payne: INTRODUCTION TO SIMULATION: Programming Techniques and Methods of Analysis Rice: MATRIX COMPUTATIONS AND MATHEMATICAL SOFTWARE Salton and McGill: Introduction to modern information retrieval Siewiorek, Bell, and Newell: Computer structures: Principles and Examples Siewiorek, Bell, and Newell: COMPUTER STRUCTURES: Principles and Example Stone: INTRODUCTION TO COMPUTER ORGANIZATION AND DATA STRUCTURES Stone and Siewiorek: INTRODUCTION TO COMPUTER ORGANIZATION AND DATA STRUCTURES: PDP-11 Edition Tonge and Feldman: COMPUTING: An Introduction to Procedures and Procedure-Followers Tremblay and Bunt: AN INTRODUCTION TO COMPUTER SCIENCE: An Algorithmic Approach Tremblay and Bunt: AN INTRODUCTION TO COMPUTER SCIENCE: AN Algorithmic Approach, Short Edition Tremblay and Manohar: DISCRETE MATHEMATICAL STRUCTURES WITH APPLICATIONS TO COMPUTER SCIENCE Tremblay and Sorenson: AN INTRODUCTION TO DATA STRUCTURES WITH APPLICATIONS Tucker: PROGRAMMING LANGUAGES Wiederhold: DATABASE DESIGN #### McGraw-Hill Advanced Computer Science Series Davis and Lenat: KNOWLEDGE-BASED SYSTEMS IN ARTIFICIAL INTELLIGENCE Kogge: THE ARCHITECTURE OF PIPELINED COMPUTERS Lindsay, Buchanan, Feigenbaum, and Lederberg: APPLICATIONS OF ARTIFICIAL INTELLIGENCE FOR ORGANIC CHEMISTRY: The Dendral Project Nilsson: Problem-solving methods in artificial intelligence Wulf, Levin, and Harbison: HYDRA/C.mmp: An Experimental Computer System 此为试读,需要完整PDF请访问: www.ertongbook.com to our parents #### **Preface** Computer Structure: Readings and Examples [Bell and Newell 1971] created a methodology to study and compare computer systems. One of the vehicles used in the book was a computer description notation: ISP. Since the ISP descriptions in Readings and Examples were used exclusively for presentation of the machines (i.e., 'read only'), the notation was not formally defined. Since the publication of Readings and Examples, we have gone through two iterations on the design and implementation of a computer description language based on ISP. The latest version, ISPS [Barbacci et al. 1977], is being used at many universities and companies as a design tool. Computer Structures: Principles and Examples [Siewiorek, Bell, and Newell 1982] uses ISPS as the computer description language. This book is designed to present the student with a notation and methodology for the analysis of computer architectures. The overall motivation is to present the space of architecture features spanned by a collection of representative machines rather than presenting yet another paper machine, designed solely for pedagogical reasons. There are several reasons why a study of real machines is a better vehicle towards an understanding of the architecture design process. Fundamentally, every architect must have an understanding of the underlying technologies used to implement a computer. Technology affects the state of the art by determining the speed and cost of the memory and central processor. These determine the basic data types and operators of the machine, the architect's building blocks. Market requirements also bias the design of instruction sets towards specific application areas, languages, or modes of operation. These two forces, together with the architect's own vision of the design space are not always in agreement and compromises must be achieved. By exploring real machines we attempt first, to understand the different dimensions of the space and second, to quantify them. It is easy to see why paper machines won't do. They are always remarkably adequate for the task on hand, a result rarely achieved in the real world. Moreover, they fail to present the complete picture: the compromises made in light of conflicting requirements, the sins committed during the design, and more important, the attempts at fixing these in later versions. Four machines, ranging from small minicomputers to large mainframes, are used as running examples. The first minicomputer, the DEC PDP-8, serves as an example of a simple Instruction Set Processor. The DEC PDP-11 represents a sophisticated 16-bit minicomputer architecture. The IBM System/370 represents the first planned computer family. Finally, the CDC 6600 is a high performance scientific architecture. In the process of writing complete formal descriptions, one must include many details that could be left out otherwise. Principles and Examples only included the complete descriptions for the simplest machines. By including complete descriptions, this book can also be used to complement Principles and Examples by presenting an orthogonal view of the computer space. While in Principles and Examples, chapters are organized around machines and the features implemented in their instruction set, this book is organized around features and the machines that include them. This organization is also suitable for the use of problems and exercises to test the student's comprehension of a topic. The book includes actual problems and suggestions for problems of the form: Compare feature X as implemented in machines A, B, and C. How would you add feature Y to machine D? How would you subset (eliminate) feature Z from machine N? Provide alternative mechanisms for a missing or incorrect implementation of a feature?, etc. Each chapter of this book is meant to illustrate some aspect of the architecture space. Each feature is presented and discussed in terms of the same set of machines. The student is assumed to have some background in digital logic, as described in courses DL-1 and DL-2 of the IEEE Curriculum [IEEE 1976], as well as some background in Assembly Language programming, numeric representation in different bases, and conversion between bases, as covered in courses CS-3 and CS-4 of the 1978 ACM Curriculum [Austing et al. 1979]. This book can be used in Computer Organization or Computer Architecture courses (IEEE CO-1, IEEE CO-3, or ACM CS-6). Many computer description languages have been proposed and one's choice must be supported by something more than pride of authorship. Initially ISP was introduced mainly for publication purposes. Its implementation as a computer language has expanded considerably its usefulness. In contrast with existing hardware description languages, ISPS is used for high level, behavioral descriptions and has been successfully used in areas outside the traditional realm of hardware descriptions: simulation and synthesis of combinational and sequential logic. ISPS has been used to drive both hardware and software generators. It has been used to evaluate computer architectures and to verify software correctness. Its use at CMU and elsewhere has produced a growing library of (real and idealized) machine descriptions, readily available for students and researchers alike [Barbacci 1981]. This achievement places ISPS in a class of its own. Finally, another incentive for its use is the availability of software (compiler, simulator, CAD systems, etc.) which can be used as laboratory tools. #### **Organization of the Book** We place a heavy emphasis on the ability to read and understand instruction set descriptions in ISPS and we provide in Chapter 1 a 'readers guide' to the notation. The material is not original and has appeared both in [Siewiorek, Bell, and Newell 1982] and [Bell, Mudge, and McNamara 1978]. In addition, earlier versions have been used for several years in computer architecture courses at Carnegie-Mellon University. Readers familiar with the notation can safely skip it. Nevertheless, it is advisable to read the last section of Chapter 1, in which we describe the convention used in writing the examples and full descriptions. The rules for capitalizing names, variables, and operators were introduced as a means to aid in the readability of ISPS. Of course, these are not part of the language, and are offered only as a guide towards good style. An instruction set processor operates by interpreting bits of information stored in the memory and registers of the machine. We begin our study of the architecture space by describing and comparing the fundamental information units. Chapter 2 introduces the different data types and the operations performed by the machines, how these operations interpret data as integers, floating point numbers, characters, strings, etc. and how the information can be mapped from one format to another. Although instructions are one more data type, they play such an important role that they deserve a separate treatment, in Chapter 3. New instruction types appear whenever a new feature is introduced. Thus, while this chapter describes the basic formats, new ones will appear throughout the book. Chapter 4 deals with the techniques use to extend the address space of the machine. Memory management, relocation, and virtual address translation are the core of the chapter. Address faults, error recovery, and interrupts are introduced here and continued in Chapters 5 and 6. Chapter 5 deals with a fundamental property of an instruction set processor, namely, the ability to modify its behavior by chosing alternative instruction sequences based on the result of previous instructions. Program control and subroutines are discussed. Arithmetic operations, because of the finite precision of the arithmetic units, have certain well defined exceptional conditions which result in the introduction of condition codes in the processor state. In this chapter we describe what these are and how they are computed across the different machines. Chapter 6 places the processor in the context of a computer system. Peripheral devices for input/output and as secondary memories constitute the main topics. Chapter 7 deals with the design of instruction sets, the symmetry and usefulness of the instructions. Chapter 8 treats architecture measurements. Our work on evaluating computer architectures for the Department of Defense is based on the use of implementation independent figures of merit. The use of abstract architecture parameters to evaluate and compare architectures and the use of a formal computer description language to drive the collection of data is a novel topic and we believe it will prove to be one of the most successful contributions of this book. Selected portions of the ISPS descriptions are included throughout the book. Sometimes, in order to keep an example concise or free of details not relevant to the topic on hand these portions have been slightly abridged. The full ISPS descriptions however, appear in the Appendices We would like to thank Dorothy Josephson who typed portions of the manuscript. Gary Leive is to be commended for his effort in the writing of the ISPS descriptions. Jin Kim, Mickey Tsao, and Andy Wilson edited the ISPS descriptions and brought them in agreement with the ISPS writing style guidelines used throughout the book. This book was edited and composed by the authors on a DECSystem10 in the Department of Computer Science at Carnegie-Mellon University. The camera-ready copy of this book was produced by the Scribe document compiler and printed on a GSI CAT-8 Photocomposer at the Campus Printing Office of Carnegie-Mellon University. Mario R. Barbacci Daniel P. Siewiorek ## Table of Contents | 1.1. Instruction Set Processor Descriptions Memory State Processor State Processor State Instruction Format Partitioning the Description 1.2. Effective Address Address Computation Indirect Addresses Auto Indexing 1.3. Instruction Interpretation Operation Code (0,AND: Logical And Operation Code (0,AND: Logical And Operation Code (1,TAD: Two's Complement Add Operation Code (3,DCA: Deposit and Clear Accumulator Operation Code (3,DCA: Deposit and Clear Accumulator Operation Code (3,DCA: Deposit and Clear Accumulator Operation Code (3,DCA: Deposit and Clear Accumulator Operation Code (3,DMP: Jump (3, | 1. | The ISPS Notation | 1 | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------| | 1.2. Effective Address 4 Address Computation 4 Indirect Addresses 5 Auto Indexing 5 1.3. Instruction Interpretation 6 Operation Code (NAND: Logical And 7 Operation Code (NAND: Operation Code (NAND: Operation Code (Nat): Increment and Skip if Zero 7 Operation Code (Nat): Deposit and Clear Accumulator 8 Author Features 9 Author Features 9 Author Features 9 Author Features 12 Packers Instructions 14 1. Data Types and Operators 15 2. Data Structures 29 2. | | Memory State Processor State Instruction Format | 2 | | 1.3. Instruction Interpretation Operation Code 0,AND: Logical And Operation Code 0,AND: Logical And Operation Code 1,TAD: Two's Complement Add Operation Code 2,ISZ: Increment and Skip if Zero Operation Code 4,JMS: Jump to Subroutine Operation Code 4,JMS: Jump to Subroutine Operation Code 6,JMP: Jump Operation Code 6,JMP: Jump Operation Code 6, Input/Output Operation Code 6, Input/Output Operation Code 7,Opr: Operate 1.4. Other Features of ISPS Constants Arithmetic Representation Sign Extension Data Operators (in order of precedence) Control Operators Predeclared Procedures 1.5. Summary and Writing Conventions 2. Data Types and Operators 2. Data Types and Operators 2. Data Structures 2. Data Structures 2. Data Struction Format 3. Instruction Format Components 1. address Instructions 1. address Instructions 0. addressing Modes 0. Inmediate Addressing 0. Immediate Addressing 0. Indirect | | 1.2. Effective Address Address Computation Indirect Addresses | 4<br>4<br>5 | | Constants 9 Arithmetic Representation 10 Sign Extension 11 Data Operators (in order of precedence) 11 Control Operators 12 Predeclared Procedures 12 1.5. Summary and Writing Conventions 14 2. Data Types and Operators 15 2.1. Basic Units 15 2.2. Data Structures 23 2.3. Problems 24 3. Instruction Formats 29 3.1. Instruction Format Components 29 n-address Instructions 30 1-address Instructions 31 0-address Instructions 31 0-address Instructions 31 0-address Instruction Address 32 3.2. Addressing Modes 32 Direct Addressing 33 Inmediate Addressing 33 Indirect Addressing 34 | | 1.3. Instruction Interpretation Operation Code 0\AND: Logical And Operation Code 1\TAD: Two's Complement Add Operation Code 2\ISZ: Increment and Skip if Zero Operation Code 3\DCA: Deposit and Clear Accumulator Operation Code 4\JMS: Jump to Subroutine Operation Code 5\JMP: Jump Operation Code 6\iot: Input/Output Operation Code 7\opr: Operate | 6<br>7<br>7<br>7<br>8<br>8<br>8<br>8 | | 2.1. Basic Units 2.2. Data Structures 2.3. Problems 2.3. Instruction Formats 2.5. Instruction Format Components 2.6. Instruction Format Components 2.7. Instruction Format Components 2.8. Instruction Format Components 2.9. Instruction Format Components 3.0. In | | Constants Arithmetic Representation Sign Extension Data Operators (in order of precedence) Control Operators Predeclared Procedures | 9<br>10<br>11<br>11<br>12 | | 2.2. Data Structures 2.3. Problems 2.4 3. Instruction Formats 2.5 3.1. Instruction Format Components 2.6 3.1. Instruction Format Components 3.7 3.1. Instruction Format Components 3.1 3.2. Address Instructions 3.3. Instruction Address 3.3. Addressing Modes 3.3. Direct Addressing 3.3. Instructions 3.4 3.5 3.6 3.7 3.7 3.7 3.8 3.8 3.8 3.9 3.9 3.9 3.9 3.9 | 2. | Data Types and Operators | 15 | | 3.1. Instruction Format Components n-address Instructions 1-address Instructions 0-address Instructions General Register Instructions Next Instruction Address 3.2. Addressing Modes Direct Addressing Immediate Addressing Indirect Addressing 3.3. Instruction Format Components 3.4. Instructions 3.5. Instructions 3.6. Instruction Addressing 3.7. Instruction Addressing 3.8. Instruction Addressing 3.9. Indirect Addressing 3.9. Indirect Addressing 3.9. Instruction Format Components 3.9. Instructions | | 2.2. Data Structures | 23 | | n-address Instructions 1-address Instructions 31 0-address Instructions 31 General Register Instructions Next Instruction Address 32 3.2. Addressing Modes Direct Addressing Immediate Addressing Indirect Addressing 33 Indirect Addressing 34 | 3. | Instruction Formats | 29 | | | | n-address Instructions 1-address Instructions 0-address Instructions General Register Instructions Next Instruction Address 3.2. Addressing Modes Direct Addressing Immediate Addressing Indirect Addressing | 30<br>31<br>31<br>32<br>32<br>33<br>33<br>34 | | Self-Modifying Indexing Modes Other Addressing Modes 3.3. Examples of Instruction Formats Mark-1 PDP-8 CDC 6600 System/370 PDP-11 3.4. Problems | 35<br>36<br>38<br>39<br>40<br>41<br>42<br>44<br>47 | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------| | 4. Memory Management | 49 | | <ul> <li>4.1. Bank Switching</li> <li>4.2. Segmentation and Paging Burroughs B 5000 DEC PDP-11 IBM System/370</li> <li>4.3. Implementation Techniques</li> <li>4.4. Problems</li> </ul> | 49<br>51<br>51<br>55<br>58<br>61<br>62 | | 5. Control and Programming Techniques | 63 | | <ul><li>5.1. Arithmetic Exceptions, Condition Codes, Skip/Branch/Jum</li><li>5.2. Loop Control</li><li>5.3. Subroutines and Coroutines</li><li>5.4. Operating System Calls, Traps, Faults, Aborts</li><li>5.5. Problems</li></ul> | p Instructions 64<br>68<br>69<br>71<br>73 | | 6. Input/Output Organization | 75 | | <ul> <li>6.1. Program Controlled Input/Output</li> <li>6.2. Interrupt Controlled Input/Output</li></ul> | 77<br>80<br>80<br>81<br>84<br>86 | | 7. Design of Instruction Sets | 89 | | <ul><li>7.1. Address Space Size</li><li>7.2. Instruction Format: Addresses, Operators, Expansion, and</li><li>7.3. Symmetry, Orthogonality, and Generality</li><li>7.4. Miscellaneous</li><li>7.5. Problems</li></ul> | Compatibility 90<br>92<br>95<br>100 | | 8. Evaluation of Computer Architectures | 105 | | 8.1. The Computer Family Architecture Project 8.2. Absolute Criteria | 105<br>106 | Table of Contents ix | 8.3. Quantitative Criteria Normalization of the Quantitative Criteria Example 8.4. Benchmarks 8.5. Problems | 108<br>115<br>117<br>121<br>123 | |---------------------------------------------------------------------------------------------------------------|---------------------------------| | I. Mark-1 ISPS Description | 123 | | | | | I.1. ** Mp.State ** I.2. ** Pc.State ** | 127<br>127 | | I.3. ** Instruction.Format ** | 127 | | I.4. ** Instruction.Execution ** | 127 | | II. PDP-8 ISPS Description | 129 | | II.1. ** Mp.State ** | 129 | | II.2. ** Pc.State ** | 129 | | II.3. ** Instruction.Format ** | 129 | | II.4. ** Address.Calculation ** | 130 | | II.5. ** Interpretation.Process ** | 130 | | II.6. ** Instruction.Set ** | 130 | | III. PDP-11 ISPS Description | 133 | | III.1. ** Mp.State ** | 134 | | III.2. ** Pc.State ** | 134 | | III.3. ** Memory.Management ** | 135 | | III.4. ** Implementation.Declarations ** | 136 | | III.5. ** Instruction.Format ** | 136 | | III.6. ** Address.Calculation ** | 137 | | III.7. ** Service.Facilities ** III.8. ** Instruction.Interpretation ** | 139<br>145 | | III.9. ** Instruction.Execution ** | 145 | | III.10. ** Integer.Extended.Op.Codes ** | 154 | | III.11. ** FP11C.Floating.Point.Processor ** | 156 | | III.12. ** Floating.Point.Processor.State ** | 156 | | III.13. ** Floating.Point.Implementation.Declarations ** | 156 | | III.14. ** Floating.Point.Instruction.Format ** | 157 | | III.15. ** Floating.Point.Service.Facilities ** {us} | 157 | | III.16. ** Floating.Point.Instruction.Execution ** {us} | 161 | | IV. System/370 ISPS Description | 169 | | IV.1. ** Mp.State ** | 169 | | IV.2. ** Pc.State ** | 170 | | IV.3. ** Implementation.Declarations ** | 171 | | IV.4. ** Instruction.Format ** | 172 | | IV.5. ** Address.Calculation ** | 172 | | IV.6. ** Service.Facilities ** {us} | 174 | | IV.7. ** Floating.Point.Operators ** {us} | 179 | | IV.8. ** Instruction.Interpretation ** {us} | 181 | |----------------------------------------------------|------------| | IV.9. ** Instruction.Decoding ** {us} | 182 | | IV.10. ** Instruction.Execution ** {us} | 187 | | V. CDC 6600 Central Processor ISPS Description | 215 | | V.1. ** Central.Memory.State ** | 216 | | V.2. ** Processor.State ** | 216 | | V.3. ** Instruction.Format ** | 216 | | V.4. ** Reservation.Control.State ** | 216 | | V.5. ** Reservation.Control ** (us) | 217 | | V.6. ** Instruction.Fetch ** {us} | 219 | | V.7. ** Central.Memory.Access ** {oc} | 220 | | V.8. ** Exchange.Jump ** {us} | 221 | | V.9. ** Instruction.Cycle ** | 222 | | V.10. ** Branch.Unit ** | 223 | | V.11. ** Boolean.Unit ** V.12. ** Shift.Unit ** | 224<br>224 | | V.13. ** Add.Unit ** | 224 | | V.14. ** Long.Add.Unit ** | 226 | | V.15. ** Multiply.Unit.0 ** | 226 | | V.16. ** Multiply.Unit.1 ** | 226 | | V.17. ** Divide.Unit ** | 227 | | V.18. ** Increment.Unit.0 ** | 227 | | V.19. ** Increment.Unit.1 ** | 229 | | VI. CDC 6600 Peripheral Processor ISPS Description | 231 | | VI.1. ** Channel.State ** | 231 | | VI.2. ** Barrel.State ** | 231 | | VI.3. ** PCP.Memory.State ** | 231 | | VI.4. ** PCP.Instruction.Format ** | 231 | | VI.5. ** Addressing.Calculation ** {us} | 232 | | VI.6. ** Barrel.Execution ** | 232 | | VI.7. ** PCP.Execution ** {oc} | 232 | | References | 237 | | Index | 239 | | | | # List of Figures | <b>Figure</b> | 1-1: | PDP-8 Declarations | 3 | |---------------|------|------------------------------------------------------|----| | Figure | | PDP-8 Instruction Interpretation | 6 | | Figure | | System/370 Floating Point Addition | 22 | | Figure | | Self-modifying Indexing Modes | 36 | | Figure | | PDP-11 Addressing Modes | 37 | | Figure | | System/370 Instruction Format | 43 | | Figure | | PDP-11 Instruction Formats | 45 | | Figure | | Segmentation Address Translation | 52 | | Figure | | Paging Address Translation | 53 | | Figure | | Segmentation on the Burroughs B 5000 | 54 | | Figure | | PDP-11 Page Address and Page Descriptor Registers | 55 | | Figure | | PDP-11 Virtual Memory Mapping | 57 | | Figure | | System/370 Segment and Page Tables | 58 | | Figure | | System/370 Memory Mapping - Part 1 | 59 | | Figure | | System/370 Memory Mapping - Part 2 | 60 | | <b>Figure</b> | 5-1: | Double Precision Addition | 67 | | <b>Figure</b> | | System/370 Instruction Cycle and Execute Instruction | 72 | | <b>Figure</b> | 5-3: | FORTRAN IF Statements on the PDP-8 and PDP-11 | 74 | | <b>Figure</b> | 6-1: | The Wheel of Reincarnation for Input/Output | 76 | | <b>Figure</b> | 6-2: | PDP-11 Paper Tape Punch | 79 | | <b>Figure</b> | | PDP-8 Interrupt Control | 81 | | <b>Figure</b> | 6-4: | A Typical PDP-8 Interrupt Handling Program | 82 | | <b>Figure</b> | 6-5: | System/370 Program Status Word | 82 | | <b>Figure</b> | 6-6: | System/370 Interrupt Handling | 83 | | <b>Figure</b> | 6-7: | PDP-11 Interrupt Service Part 1 | 85 | | <b>Figure</b> | 6-8: | PDP-11 Interrupt Service Part 2 | 86 | ### List of Tables | | | 2.0001130100 | | |--------------|-------|-------------------------------------------------------------------------------------------------------------|----------| | Table | | The Hierarchy of Basic Units | 15 | | Table | | Comparison of Three Floating Point Number Representations | 18 | | Table | 2-3: | Characteristics of Single Precision Floating Point Representations for Four | 19 | | | | Example Computers. | | | Table | | The Hierarchy of Data Structures Constructed from Basic Units | 23 | | Table | | Typical Operations | 25 | | Table | | Instruction Format Dimensions | 30 | | Table | | Addressing Modes | 33 | | Table | | Summary of Addressing Modes | 39 | | Table | | CDC 6600 Set Ai (SAi) Instructions | 41 | | Table | | PDP-11 Program Counter Addressing Modes | 46 | | Table | | Summary of Instruction Formats | 46 | | Table | | Range of Program Control | 63 | | Table | | General Exceptions | 63 | | Table | | Arithmetic Exceptions | 64<br>66 | | Table | | Branch Instructions by Class | 89 | | Table | | Issues in the Design of an Instruction Set | 92 | | Table | | Partial Instruction Decoding for the PDP-11 Example Unary and Binary Operations for a General Register ISP | 94 | | Table Table | | CDC 6600 SAi, SBi, and SXi Instructions | 94 | | Table | | Huffman Example | 97 | | Table | | Impact on memory space for various op-code encoding techniques on the | 98 | | lable | 7-0. | Burroughs B 1700 Master Control Program | 30 | | Table | 7-7: | Execution Frequency for Top 36 PDP-11 Instructions, Example Huffman | 99 | | labic | | Encoding by Frequency and Operation Code Lengths for the Huffman | 00 | | | | Encoding and the PDP-11 Assignment | | | Table | 7-8: | Frequency of Operation Code Lengths for the 36 Most Frequently Executed | 100 | | | | Instructions as Assigned in the PDP-11 and a Huffman Encoding | | | Table | 7-9: | Measured relative operation code frequencies for Basic and Pascal programs | 102 | | | | on the PDP-11 | | | <b>Table</b> | 7-10: | Measured relative branch distances for the PDP-11 [Strecker 1976] | 103 | | | 7-11: | Relative frequency of PDP-11 Addressing Modes [Strecker 1976] | 104 | | | 7-12: | Relative Instruction Execution Frequencies for Three System/370 Programs | 104 | | | | [Shustek 1978] | | | <b>Table</b> | 8-1: | Initial CFA Candidates | 105 | | <b>Table</b> | 8-2: | Summary of Absolute Criteria | 108 | | <b>Table</b> | 8-3: | Virtual Address Space Measures | 109 | | <b>Table</b> | 8-4: | Physical Address Space Measures | 110 | | <b>Table</b> | 8-5: | Unassigned Instruction Space Measures | 111 | | <b>Table</b> | 8-6: | Size of Pc State | 111 | | <b>Table</b> | 8-7: | Usage Base Measures | 112 | | <b>Table</b> | 8-8: | I/O Initiation Measures | 113 | | <b>Table</b> | | Virtualizability | 113 | | | 8-10: | | 114 | | | 8-11: | Maximum Interrupt Latency Measures | 115 | | | 8-12: | Subroutine Linkage Measures | 115 | | | 8-13: | Quantitative Measure Weights | 117 | | | 8-14: | Summary of Quantitative Criteria | 117 | | Table | 8-15: | Virtual Memory Space Size VM | 118 | | Table 8-16: | Processor State Size PS | 119 | |--------------------|-----------------------------------------------------|-----| | <b>Table 8-17:</b> | Ranking of Architectures | 119 | | <b>Table 8-18:</b> | Double Normalized Data | 120 | | Table 8-19: | Ranking of Architectures After Double Normalization | 120 | | Table 8-20: | Ranking After Eliminating Mark-1 and PDP-8 | 121 | | <b>Table 8-21:</b> | Unused PDP-11 Operation Code Space | 125 | The ISPS Notation 1 #### 1. The ISPS Notation This chapter introduces the reader to the ISPS notation. Although some details have been excluded, it covers enough of the language to provide a *reading* capability, to permit the reading and study of complex descriptions. For a detailed explanation of the complete language the reader must consult the ISPS reference manual [Barbacci et al. 1977]. #### 1.1. Instruction Set Processor Descriptions To describe an Instruction Set Processor (ISP), we need to define the operations, instructions, data types, and interpretation rules used in the machine. These will be introduced gradually, as we describe the primary memory state, the processor state, and the interpretation cycle. Primary memory is not, in a strict sense, part of the Instruction Set Processor but it plays such an important role in its operation that it is typically included in the description. In general, data types (integers, floating point numbers, characters, addresses etc.) are abstractions of the contents of the machine registers and memories. One data type that requires explicit treatment is the "instruction" and we shall explore the interpretation of instructions in great detail. We will use the DEC PDP-8 ISPS description as a source of examples. #### Memory State The description of the PDP-8 begins by specifying the primary memory that is used to store data and instructions: $M\Memory[0:4095] < 0:11 >$ , The primary memory is declared as an array of 4096 words, each 12 bits wide. The memory has a name "M", and an alias "Memory". These aliases are a special form of a comment and are useful for indicating the meaning or usage of a register's name. As in most programming languages, ISPS identifiers consist of letters and digits, beginning with a letter. The character "." is also allowed, to increase the readability. The expression [0:4095] describes the structure of the array. It declares the size (4096 words) and the names of the words (0,1,...,4094,4095). The expression <0:11> describes the structure of each individual word. It declares the size (12 bits) and the names of the bits (0,1,...,10,11). It should be noted that bit and word *names* are precisely that, i.e., identifiers for the subcomponents of a memory structure. These names do not necessarily indicate the relative position of the subcomponents. Thus, R < 7:3 > is a valid definition of a 5-bit register. The fact that the five bits are named 7,6,5,4,3 should not be confused with the 7th, 6th, etc. positions inside the register. Thus, bit 7 is the leftmost bit, bit 6 is located in the next position towards its right, etc., while bit 3 is the rightmost bit.