# ADVANCED MICROPROCESSOR ARCHITECTURES

LUIGI CIMINIERA & ADRIANO VALENZANO





**Electronic Systems Engineering Series** 

# ADVANCED MICROPROCESSOR ARCHITECTURES

# Luigi Ciminiera Adriano Valenzano

Politecnio di Torino, Italy



## **Addison-Wesley Publishing Company**

Wokingham, England • Reading, Massachusetts • Menlo Park, California New York • Don Mills, Ontario • Amsterdam • Bonn • Sydney Singapore • Tokyo • Madrid • Bogota • Santiago • San Juan

- © 1987 Addison-Wesley Publishers Limited
- © 1987 Addison-Wesley Publishing Company, Inc.

All rights reserved. No part of this publication may be reproduced, stored in a retrieval system, or transmitted in any form or by any means, electronic, mechanical, photocopying, recording, or otherwise, without prior written permission of the publisher.

The programs presented in this book have been included for their instructional value. They have been tested with care but are not guaranteed for any particular purpose. The publisher does not offer any warranties or representations, nor does it accept any liabilities with respect to the programs.

The Publishers have made every attempt to supply trademark information about company names and products mentioned in this book. Those listed are derived from various sources.

Cover design by Sampson/Tyrell Limited. Illustrations by Chartwell Illustrators. Typeset by Columns, Reading, Berks. Printed in Great Britain by The Bath Press.

First printed 1987.

## **British Library Cataloguing in Publication Data**

Ciminiera, Luigi

Advanced microprocessor architectures.

1. Microprocessors – Design and construction

I. Title II. Valenzano, Adriano

621.392 TK7895.M5

ISBN 0-201-14550-2

# Library of Congress Cataloguing in Publication Data Ciminiera, Luigi.

Advanced microprocessor architectures.

Includes bibliographies and index.

1. Microprocessors. 2. Computer architecture.

I. Valenzano, Adriano. II. Title.

QA76.5.C527 1987 004.2'2 87-1081

ISBN 0-201-14550-2

# ADVANCED MICROPROCESSOR ARCHITECTURES

### **ELECTRONIC SYSTEMS ENGINEERING SERIES**

Consulting Editor

E L Dagless

University of Bristol

#### OTHER TITLES IN THE SERIES

Modern Logic Design  $\ D$  Green Communications and Computer Networks  $\ F$  Halsall Microwave Components and Systems  $\ K$  F Sander

此为试读,需要完整PDF请访问: www.ertongbook.com

# **PREFACE**

The advances achieved by microprocessors since their first appearance in the early 1970s are surprising, even in the rapidly evolving field of computers. The introduction of new features has caused technical innovations, in addition to changes in the technical background required to cope with them.

Early microprocessors were rather simple devices and the major problems encountered by users were concerned with developing programs in assembly language and interfacing to memory and I/O devices. In this framework, the typical microprocessor expert was usually an electronic engineer, with a hardware-oriented background, who was able to design rather small programs for modest application needs. From this point of view, the electronic engineer was regarded as a specialist in designing particular kinds of electronic circuits.

New 16- and 32-bit microprocessors include in their architectures features and supports that have been borrowed largely from minicomputer and mainframe technologies, and which rely heavily on the rapid progress achieved in the computer engineering and computer science fields. The main consequence of this is that microprocessor experts must now regard these devices as complex 'systems' rather than as special-purpose components. Hence, many of the basic concepts, such as those concerning operating systems, parallel processing and high-level language programming, must be included in the technical background of each modern microsystem designer.

#### Aims

The major goal of this book is to contribute to the technical knowledge needed by every modern microprocessor expert. It does this by addressing the main aspects underlying the design of modern microprocessor architectures. Since new commercial device families include sophisticated support for operating system implementation, memory management, high-level language programming, floating-point computations and so on, this book presents the main concepts on which these mechanisms are based, and discusses them in the light of their impact on modern microprocessor architectures. In addition, some important examples of commercial microprocessors are presented to illustrate how these basic principles are reflected in the 'real' world.

In other words, this book introduces advanced microprocessors from a point of view that does not merely use the conventional description of their hardware characteristics, but tries to offer a comprehensive picture of the philosophy that led to the design of modern architectures.

# Intended Audience and Prerequisite Knowledge

This book is suited to undergraduate students in Electronic Engineering and Computer Engineering wishing to learn the fundamentals of advanced microprocessor architectures. At the same time, the book is also oriented to postgraduate students and engineers needing to be abreast of technical progress in modern device families.

Microprocessor-based system designers and computer engineering professionals will find in this book up-to-date material on the main features and characteristics of advanced microprocessors, together with the most important examples of commercial architectures.

The reader should be familiar with simple (8-bit) microprocessors, possibly by having attended a first-level course on microprocessor architectures. In particular, he or she is expected to have a knowledge of the basic organization of computers, and to have gained some experience in assembly and high-level language programming techniques.

The book is oriented to an advanced course on microprocessors. Since the early chapters present several fundamental concepts concerning operating systems and high-level languages, the reader can derive greater benefit from attending former or parallel courses on operating system principles and compiler construction. In this way, he or she will be able to understand, on the one hand, how operating system and compiler principles are implemented in practice, while, on the other hand, fundamental concepts will be mastered in detail.

# Organization

The book is organized into two groups of chapters. Chapters 1 to 4 introduce the most important architectural characteristics of advanced microprocessors from a general point of view, without particular emphasis on any specific device. In contrast, Chapters 5 to 10 present the most popular and significant 'real' architectures, making use of the basic elements discussed in the early chapters.

- Chapter 1 summarizes the factors that led to modern design philosophy and deals with characteristics concerning data types, addressing modes and microprocessor instruction organization.
- Chapter 2 describes other important architectural features such as register organization, floating-point number representation and standardization, the role of the interrupt and trap mechanisms, and the function of some hardware and software debugging supports.
- Chapter 3 is devoted to multiprocessing and multitasking; thus, specific sections describe some basic concepts of operating systems such as process switching, mutual exclusion, process synchronization, process communication and process scheduling.
- Chapter 4 deals with memory management: memory hierarchy is discussed together with memory management mechanisms such as segmentation and paging. Further concepts, such as virtual memory and memory protection principles and supports, are also introduced.
- Chapters 5, 6, 7 and 8 present four popular 16- and 32-bit microprocessors: Zilog Z80000, Motorola MC68020, National Semiconductor NS32032 and Intel iAPX286.
- Chapter 9 describes the Intel iAPX432 system, perhaps the most important example of a 'capability-based' machine implemented on a few VLSI chips.
- The aim of the last chapter (Chapter 10) is to give the reader a taste of the emerging reduced instruction set (RISC) architecture approach, which has appeared in the last few years. For this purpose, some basic principles and examples concerning the RISC philosophy are presented.

Problems related to memory and I/O interfacing are not covered in this book, because advanced microprocessors do not show significant innovations in this field and, moreover, it is assumed that the reader has already been introduced to them by a previous course or by his or her own experience.

Each chapter is concluded by a set of questions and problems concerning the main topics introduced in the preceding sections. The main goal of these exercises is to supply the reader with an immediate and continuous means for checking his or her progress in understanding the concepts and principles presented throughout the book.

On the other hand, the set of problems presented in the appendix

is oriented to typical aspects of modern microprocessor-based system design. The aim of these exercises is to lead the reader to a critical evaluation of the possible alternative solutions that can be adopted for 'real' problems. At the same time, some small design examples are proposed to spur the reader's fancy and creativity.

Luigi Ciminiera Adriano Valenzano July 1987

## Acknowledgements

We are grateful to Professor Erik Dagless for his help and his many valuable comments and suggestions on early drafts of the book. We would also express our gratitude to Addison-Wesley for the cooperation and the comprehension shown by everyone during the preparation of the book. We would especially like to thank Simon Plumtree, Executive Editor, for his continuous encouragement and for solving several of the problems met in writing the manuscript. Finally, we would like to thank Zilog, Motorola, National Semiconductor, Intel and Inmos for supplying and providing permission to reproduce technical material that enhanced the accuracy of the book. The following material is adapted and reproduced courtesy of:

- Zilog Corporation: *Z80000 CPU Preliminary Product Specifications* (1985) Figures 4 (5.8), 5 (5.1), 7 and 8 (5.10), 10 (5.11) and Tables 2 (5.2), 5 (5.1).
- Motorola Corporation: *MC68020 32 Bit Microprocessor User's Manual*, Prentice-Hall Inc. (1985) Figures 1–1 (6.1), 1–2 (6.5), 1–3 (6.6), 4–1 (6.2), 8–4 (6.13), 8–8 (6.14), D–3 (6.11) and Tables 2–1 (6.8), 6–2 (6.2); Motorola Semiconductors: *MC68881 FPCP Technical Summary* (1985) Figure 1(a) (6.21) and Tables 7 (6.4), 9 (6.5); Motorola Semiconductors: *MC68851 MMMU Pre-Specs* (1985) Figure 9–3 (6.19).
- National Semiconductor Corporation: *Series 320000 Databook* (1984) Figures 1 (7.1), 2–6 (7.8), 2–8 (7.5), 3–2 (7.15), 3–5 (7.13), 3–10 (7.17), 3–22 (7.11), 3–23 (7.10).
- Intel Corporation: *iAPX286 Hardware Reference Manual* (1983) Figures 1 (8.19), 3–1 (8.1), 5 (8.21) and 6 and 9 (8.22), and Table 1 (8.1); *iAPX286 Programmer's Reference Manual* 2–4 (8.2), 2–10 (8.5), 2–12 (8.3), 4–2a and 4–2b (8.6), 6–1 (8.7), 6–3 (8.9), 6–4 (8.11), 6–5 (8.12), 6–6 (8.8), 6–7 (8.10), 6–8 (8.13), 7.10 (8.14), 7–11 (8.15), 8–1 (8.17), 8–3 (8.16), 9–2 (8.18).
- Inmos Limited: Transputer Architecture (1985) (10.6); IMS T414 Transputer Product Data (1985) – (10.7).
- IEEE: D. A. Patterson, C. H. Sequin, 'A VLSI RISC', Computer, September 1982, pp. 8–21 (©IEEE) Figures 1 (10.2), 3 (10.1) and Table 4 (10.1); Whitby-Stevens, Proc. 12th Ann. Symp. on Computer Architecture, June 1985, pp. 292–300 (©IEEE) Figures 1 (10.9), 2 (10.10).
- Computer Science Press, Incorporated: S. A. Przybylski et al., 'Organization and VLSI Implementation of MIPS', J. VLSI and Computer

#### **ACKNOWLEDGEMENTS**

Systems, 1 (2), pp. 170–208 – Figures 1 (10.5), 3 (10.3), 5 (10.4) and Tables 1 (10.2), 2 (10.3).

## **Trademarks**

Z8000, Z80000, Z8070 and Zilog are trademarks of Zilog Corporation. MC68000, MC68020, MC68851, MC68881, MC60008, MC68010 and Motorola are trademarks of Motorola Corporation.

NS32032, NS32202, NS32201, NS32081, NS32082 and National Semiconductor are trademarks of National Semiconductor Corporation.

8089, 80287, iAPX432, iAPX286, iAPX186/88, iAPX86/88 and Intel are trademarks of Intel Corporation.

Transputer, Occam, T414 and Inmos are trademarks of the Inmos Group of Companies.

VAX-11 is a trademark of Digital Equipment Corporation.

Am9511 is a trademark of Advanced Micro Devices Incorporated.

# **CONTENTS**

| Preface   |                                                                            | 1   |
|-----------|----------------------------------------------------------------------------|-----|
| Chapter 1 | Microprocessor Architecture: Data Types, Addressing Modes and Instructions | 1   |
| 1.1       | The evolution of microcomputers: A brief history                           | 2   |
| 1.2       | The semantic gap                                                           | 7   |
| 1.3       | Architecture classification                                                | 5   |
| 1.4       | Memory allocation in high-level languages                                  | 8   |
| 1.5       | Data types                                                                 | 14  |
| 1.6       | Addressing modes                                                           | 29  |
| 1.7       | Instructions                                                               | 57  |
| 1.8       | Conclusion                                                                 | 65  |
| Chapter 2 | Other Architectural Features of Microprocessors                            | 69  |
| 2.1       | Register organization                                                      | 70  |
| 2.2       | Floating-point numbers                                                     | 82  |
| 2.3       | Interrupts                                                                 | 88  |
| 2.4       | Traps                                                                      | 95  |
| 2.5       | Debugging supports                                                         | 97  |
| 2.6       | Conclusion                                                                 | 100 |
| Chapter 3 | Multiprogramming and Multitasking                                          | 105 |
| 3.1       | Introduction                                                               | 106 |
| 3.2       | Processes and processors                                                   | 109 |
| 3.3       | Interleaved process execution                                              | 110 |
| 3.4       | Process switching                                                          | 111 |
| 3.5       | Mutual exclusion                                                           | 114 |
| 3.6       | Synchronization                                                            | 121 |
| 3.7       | Process communication                                                      | 126 |
| 3.8       | Processor scheduling                                                       | 132 |
| 3.9       | Conclusion                                                                 | 139 |

| Chapter 4 | Memory Management                       | 143 |
|-----------|-----------------------------------------|-----|
| 4.1       | Introduction                            | 144 |
| 4.2       | Program locality                        | 145 |
| 4.3       | Virtual and physical addresses          | 146 |
| 4.4       | Memory hierarchy                        | 146 |
| 4.5       | Simple management mechanisms            | 156 |
| 4.6       | Swapping                                | 160 |
| 4.7       | Segmentation                            | 161 |
| 4.8       | Paging                                  | 164 |
| 4.9       | Principles of memory protection         | 169 |
| 4.10      |                                         | 170 |
| 4.11      |                                         | 172 |
| 4.12      |                                         | 173 |
| 4.13      |                                         | 174 |
|           | Hardware memory protection              | 175 |
| 4.15      | Conclusion                              | 181 |
|           |                                         |     |
| Chapter 5 | The Zilog Z80000 Family                 | 187 |
| 5.1       | Introduction                            | 188 |
| 5.2       | CPU architecture                        | 188 |
| 5.3       | Cache memory                            | 193 |
| 5.4       | Basic data types                        | 195 |
| 5.5       | Registers                               | 196 |
| 5.6       | Addressing modes                        | 199 |
| 5.7       | Instruction set                         | 202 |
| 5.8       | Exceptions                              | 208 |
| 5.9       | Memory management                       | 212 |
| 5.10      | Co-processors                           | 217 |
| 5.11      | The Z8070 floating-point co-processor   | 218 |
| 5.12      | Conclusion                              | 228 |
|           |                                         |     |
| Chapter 6 | The Motorola MC68020 Family             | 231 |
| 6.1       | Introduction                            | 232 |
| 6.2       | CPU architecture                        | 232 |
| 6.3       | Cache memory                            | 236 |
| 6.4       | Basic data types                        | 238 |
| 6.5       | Registers                               | 240 |
| 6.6       | Addressing modes                        | 244 |
| 6.7       | Instruction set                         | 249 |
| 6.8       | Exceptions                              | 259 |
| 6.9       | Co-processors                           | 263 |
| 6.10      | Memory management                       | 266 |
| 6.11      | The MC68881 floating-point co-processor | 275 |
| 6.12      | 2 Conclusion                            | 279 |

|            |                                           | CONTENTS | xiii       |
|------------|-------------------------------------------|----------|------------|
| Chapter 7  | The National Semiconductor NS32032 Family |          | 283        |
| 7.1        | Introduction                              |          | 284        |
| 7.2        | CPU architecture                          |          | 284        |
| 7.3        | Basic data types                          |          | 287        |
| 7.4        | Registers                                 |          | 289        |
| 7.5        | Addressing modes                          |          | 292        |
| 7.6        | Instruction set                           |          | 298        |
| 7.7        | Exceptions                                |          | 305        |
| 7.8        | Co-processors                             |          | 312        |
| 7.9        | Memory management                         |          | 313        |
| 7.10       | The NS32081 floating-point co-processor   |          | 322        |
| 7.11       | Custom co-processors                      |          | 324        |
| 7.12       | Conclusion                                |          | 325        |
| Chapter 8  | The Intel iAPX286 System                  |          | 329        |
| 8.1        | Introduction                              |          | 330        |
| 8.2        | CPU architecture                          |          | 331        |
| 8.3        | Basic data types                          |          | 336        |
| 8.4        | Registers                                 |          | 337        |
| 8.5        | Addressing modes                          |          | 341        |
| 8.6        | Instruction set                           |          | 343        |
| 8.7        | Memory management and protection          |          | 351        |
| 8.8        | Privileged machine states                 |          | 359        |
| 8.9        | Task control information and switching    |          | 363        |
| 8.10       | Interrupts and traps                      |          | 368        |
| 8.11       | The arithmetic co-processor               |          | 374        |
| 8.12       | Conclusion                                |          | 383        |
| Chapter 9  | The Intel iAPX432 System                  |          | 387        |
| 9.1        | Introduction                              |          | 388        |
| 9.2        | System architecture                       |          | 389        |
| 9.3        | Objects                                   |          | 391        |
| 9.4        | Object addressing                         |          | 392        |
| 9.5        | Program organization                      |          | 396        |
| 9.6        | Objects for procedure execution           |          | 398        |
| 9.7        | User-defined types                        |          | 403        |
| 9.8        | Multiprocessing support                   |          | 407        |
| 9.9        | Objects for memory management             |          | 416        |
| 9.10       | The iAPX432 interconnect system           |          | 423        |
| 9.11       | Fault handling in the iAPX432 system      |          | 430<br>437 |
| 9.12       | Conclusion                                |          | 43/        |
| Chapter 10 | Reduced Architectures                     |          | 441        |
| 10.1       | Introduction                              |          | 442        |
| 10.2       | RISC approach                             |          | 442        |

| XIV | CONTENTS |
|-----|----------|

| 10.3<br>10.4<br>10.5<br>10.6 | Berkeley RISC<br>MIPS<br>The Inmos Transputer<br>Conclusion | 443<br>449<br>454<br>462 |
|------------------------------|-------------------------------------------------------------|--------------------------|
| Appendix                     | Further Problems                                            | 465                      |
| Index                        |                                                             | 469                      |

# CHAPTER 1

# MICROPROCESSOR ARCHITECTURE: DATA TYPES, ADDRESSING MODES AND INSTRUCTIONS

#### **OBJECTIVES**

The aims of this chapter are as follows:

- to look at the historical trends in the microprocessor evolution;
- to explain the typical memory allocation and operations required to run programs written in high-level languages;
- to explain how data types supported by advanced microprocessors can be used to implement data structures used in high-level languages;
- to show how the addressing modes of advanced microprocessors work, and how they can be used to access data in those memory organizations needed to implement programs written in high-level languages;
- to outline how some special instructions can be used to implement some typical operations required by high-level languages.
- 1.1 The evolution of microcomputers: A brief history
- 1.2 The semantic gap
- 1.3 Architecture classification
- 1.4 Memory allocation in highlevel languages
- 1.5 Data types
- 1.6 Addressing modes
- 1.7 Instructions
- 1.8 Conclusion

# 1.1 The evolution of microcomputers: A brief history

In a book devoted to the most recent advances in microprocessor architecture, it is not possible to avoid a brief description of the short, but intense, history of microcomputers. In a field that is evolving so rapidly, the technological scenario is also changing continuously; thus, to understand the current state of the art it is necessary to know the trends of the microprocessor evolution and their bearing on future developments. The first section of this book is devoted to a brief description of the major events in the microprocessor evolution, therefore following microprocessors' original introduction to the market.

Although companies such as General Electric, RCA and Viatron contributed to microprocessor developments prior to 1971, the Intel 4004, introduced at the end of 1971, is generally acknowledged as the first microprocessor commercially available. Not long after, in 1972, other microprocessors were announced and introduced, such as the Rockwell International 4-bit PPS-4, the Intel 8-bit 8008 and the National Semiconductor 16-bit IMP-16.

The motivations leading to the first microprocessor implementations were dictated by the increased demand for large control circuits, which could not be effectively implemented with the dedicated chips then available. Thus, the microprocessor was originally seen as a programmable electronic device that could replace hard-wired circuits used in the implementation of small peripheral controllers, such as printers, intelligent terminals and pocket calculators. The field of application and the technology available dictated the technical characteristics of such a device; for example, the 8008 had an 8-bit data path, 14-bit address (16 Kbytes address space), an instruction set providing capabilities to perform simple arithmetic (addition, subtraction) and logical operations on 8-bit integers, and a stack implemented in hardware within the CPU, with a limited size, which prevented the execution of software with a complex structure.

With further developments in integration technology it became possible for an ever increasing number of transistors to be implemented on the same silicon area, so that the microprocessor designer was faced with the problem of using the area freed by the technological advances.

From 1973 to 1977, only a few years after their first appearance, microprocessors were characterized by an 8-bit data path and a 16-bit address (64 Kbytes addressing space); the instruction set was enlarged to include some 16-bit data manipulations, since this feature enabled address computations, and the stack was implemented in main memory, allowing subroutine nesting to a large degree. The typical applications for these microprocessors (often referred to as 8-bit) were still found in the field of real-time control, as well as in industrial applications. Software was almost always written in assembly language because the relatively low