

# AT&T 3B2/3B5/3B15 Computers Assembly Language Programming Manual

**AT&T** 

## ACKNOWLEDGEMENTS

Prepared and published by Document Development Organization – Microelectronics Projects Group AT&T Network Systems, Morristown

for the

Microsystems Product Management AT&T Technologies, Inc.

and the

AT&T Computer Systems Center Lisle, Illinois

## A WORD ABOUT TRADEMARKS . . .

The following AT&T registered trademarks are mentioned in this manual:

WE® 32001 Processor Module

WE® 32100 Microprocessor

WE® 32101 Memory Management Unit

WE® 32106 Math Acceleration Unit

WE® 321AP Microprocessor Analysis Pod

WE® 321DS Microprocessor Development System

WE® 321SD Development Software Programs

WE® 321SG Software Generation Programs

#### AT&T 3B2/3B5/3B15 Computers are trademarks of AT&T.

UNIX<sup>TM</sup> Operating System is a trademark of AT&T.

AT & T reserves the right to make changes to the product(s), including any hardware, software, and/or firmware contained therein, described herein without notice. No liability is assumed as a result of the use or application of this product(s). No rights under any patent accompany the sale of any such product(s).

Copyright © 1986 AT & T. All Rights Reserved. Printed in United States of America

Select Code 305-000



## **AT&T** 3B2/3B5/3B15 Computers Assembly Language Programming Manual

The information contained herein is subject to change.

## ACKNOWLEDGEMENTS

Prepared and published by Document Development Organization – Microelectronics Projects Group AT&T Network Systems, Morristown

for the

Microsystems Product Management AT&T Technologies, Inc.

and the

AT&T Computer Systems Center Lisle, Illinois

## A WORD ABOUT TRADEMARKS . . .

The following AT&T registered trademarks are mentioned in this manual:

WE® 32001 Processor Module

WE® 32100 Microprocessor

WE® 32101 Memory Management Unit

WE® 32106 Math Acceleration Unit

WE® 321AP Microprocessor Analysis Pod

WE® 321DS Microprocessor Development System

WE® 321SD Development Software Programs

WE® 321SG Software Generation Programs

AT&T 3B2/3B5/3B15 Computers are trademarks of AT&T.

UNIX<sup>TM</sup> Operating System is a trademark of AT&T.

AT & T reserves the right to make changes to the product(s), including any hardware, software, and/or firmware contained therein, described herein without notice. No liability is assumed as a result of the use or application of this product(s). No rights under any patent accompany the sale of any such product(s).

Copyright © 1986 AT & T. All Rights Reserved. Printed in United States of America

Select Code 305-000

#### FOREWORD

This manual is intended for 3B Computer users with a need to program in assembly language. Emphasis is on the WE 32100 Microprocessor and its floating point support. The more general IS25 instructions are referenced in an appendix.

Data organization and storage, and WE 32100 Microprocessor (CPU) addressing modes are discussed prior to the instruction set. The instructions are grouped functionally into data transfer arithmetic, logical, program control, coprocessor, stack, and miscellaneous types. Mnemonics, op-codes, bytes, cycles counts, and effect on flag bits are tabulated for each instruction. Detailed descriptions of each instruction are given in the appendix. The CPU's operating system instructions are also referenced.

Assembler and disassembler options, along with a description of assembler directives and macro processing facilities, are presented. The WE 32106 Math Acceleration Unit assembly language instructions are detailed along with the alternative floating point emulation library of functions.

To obtain additional copies of this manual, Select Code 305-000, call:

## ASSEMBLY LANGUAGE PROGRAMMING MANUAL

#### FOR THE AT&T 3B2/3B5/3B15 COMPUTERS

#### CONTENTS

## **CHAPTER 1. INTRODUCTION**

| 1. INTRODUCTION | 1-1 |
|-----------------|-----|
| 1.1 OVERVIEW    | 1-1 |
| 1.2 DEVELOPMENT | 1-2 |

## CHAPTER 2. ARCHITECTURE

| 2. ARCHITECTURE OF THE WE 32100 MICROPROCESSOR | 2-1 |
|------------------------------------------------|-----|
| 2.1 ASSEMBLY LEVEL SUPPORT GROUP               | 2-3 |
| 2.2 HIGH-LEVEL LANGUAGE SUPPORT GROUP          | 2-4 |
| 2.3 OPERATING SYSTEM SUPPORT GROUP             | 2-5 |

#### CHAPTER 3. ASSEMBLY LANGUAGE STRUCTURE

| 3. ASSEMBLY LANGUAGE STRUCTURE              | 3-1                                    |
|---------------------------------------------|----------------------------------------|
| 3.1 STATEMENTS                              | 3-1                                    |
| 3.2 EXECUTABLE INSTRUCTIONS                 | 3-2                                    |
| 3.3 SYMBOLS                                 | 3-3                                    |
| 3.3.1 Values and Types                      | 3-4                                    |
| 3.3.2 Assigning Values and Types to Symbols | 3-4                                    |
| 3.4 EXPRESSIONS                             | 3-5                                    |
| 3.4.1 Constants                             | 3-6                                    |
| 3.4.2 Registers                             | 3-6                                    |
| <ul> <li>3.3 SYMBOLS</li></ul>              | 3-3<br>3-4<br>3-4<br>3-5<br>3-6<br>3-6 |

## CHAPTER 4. DATA ORGANIZATION

| 4. I | DATA ORGANIZATION             | 4-1 |
|------|-------------------------------|-----|
| 4.1  | DATA TYPES                    | 4-1 |
| 4.2  | DATA STORAGE IN MEMORY        | 4-3 |
| 4.3  | REGISTER DATA STORAGE         | 4-3 |
| 4.4  | INSTRUCTION STORAGE IN MEMORY | 4-4 |

## **CHAPTER 5. ADDRESSING MODES**

| 5. AD  | DRESSING MODES            | 5-1 |
|--------|---------------------------|-----|
| 5.1 RJ | EGISTER MODE              | 5-4 |
| 5.2 RJ | EGISTER DEFERRED MODE     | 5-5 |
| 5.3 D  | ISPLACEMENT MODE          | 5-6 |
| 5.4 DI | EFERRED DISPLACEMENT MODE | 5-8 |
| 5.5 IN | MMEDIATE MODE             | 5-9 |

¥

| 5.6 | ABSOLUTE MODE          | 5-10 |
|-----|------------------------|------|
| 5.7 | ABSOLUTE DEFERRED MODE | 5-10 |
| 5.8 | EXPANDED OPERAND MODE  | 5-11 |
| 5.9 | SUMMARY                | 5-13 |

## CHAPTER 6. INSTRUCTION SET

| 6. IN | ISTRUCTION SET                          |
|-------|-----------------------------------------|
| 6.1 V | VE 32100 MICROPROCESSOR INSTRUCTION SET |
| 6.1.1 | Condition Flags                         |
| 6.2 F | UNCTIONAL GROUPS                        |
| 6.2.1 | Data Transfer Instructions              |
| 6.2.2 | Arithmetic Instructions                 |
| 6.2.3 | Logical Instructions                    |
| 6.2.4 | Program Control Instructions            |
| 6.2.5 | Coprocessor Instructions                |
| 6.2.6 | Stack and Miscellaneous Instructions    |

## CHAPTER 7. USING THE as ASSEMBLER

| 7. US  | SING THE as ASSEMBLER                  | 7-1  |
|--------|----------------------------------------|------|
| 7.1 O  | VERVIEW OF ASSEMBLY PROCESS            | 7-1  |
| 7.2 as | SASSEMBLER                             | 7-1  |
| 7.2.1  | Assembled Files                        | 7-3  |
| 7.2.2  | Diagnostics                            | 7-3  |
| 7.3 A  | SSEMBLER DIRECTIVES                    | 7-3  |
|        | Location Counter                       | 7-4  |
| 7.3.1  | Section Control Pseudo-Operations      | 7-5  |
| 7.3.2  | Pseudo-Operations Dealing With Symbols | 7-7  |
| 7.3.3  | Assignment Pseudo-Operations           | 7-8  |
| 7.3.4  | Assignment to Dot                      | 7-9  |
| 7.3.5  | Alignment Pseudo-Operations            | 7-9  |
| 7.3.6  | Data Generation Pseudo-Operations      | 7-9  |
| 7.3.7  | Symbolic Debugging Pseudo-Operations   | 7-10 |
| 7.3.8  | File Name Pseudo-Operations            | 7-12 |
| 7.3.9  | Line Number Pseudo-Operations          | 7-12 |
| 7.4 M  | IACRO PROCESSING FACILITIES            | 7-12 |
| 7.4.1  | Interface Macros                       | 7-13 |
|        | Function Interface Macros              | 7-13 |
|        | Scratch Register Macros                | 7-14 |
|        | Stack Frame Macros                     | 7-14 |
|        | Restrictions                           | 7-15 |
| 7.4.2  | Using Predefined Macros                | 7-15 |
|        | Examples                               | 7-15 |
| 7.4.3  | M4 Reserved Words                      | 7-17 |
|        |                                        |      |

## CHAPTER 8. THE dis DISASSEMBLER

| 8. THE dis DISASSEMBLER       | 8-1 |
|-------------------------------|-----|
| 8.1 INVOKING THE DISASSEMBLER | 8-1 |

| 8.2 DISASSEMBLY LISTING             | 8-2 |
|-------------------------------------|-----|
| 8.2.1 Using the Disassembly Listing | 8-3 |
| 8.3 ERROR MESSAGES                  | 8-3 |

## CHAPTER 9. OPERATING SYSTEM INTERFACE

| 9. OPERATING SYSTEM INTERFACE                                     | 9-1 |
|-------------------------------------------------------------------|-----|
| 9.1 FEATURES OF THE OPERATING SYSTEM                              | 9-1 |
| 9.1.1 Memory Management Considerations for Virtual Memory Systems | 9-4 |

#### CHAPTER 10. FLOATING POINT SUPPORT

| 10. FLOATING POINT SUPPORT                                      | 10-1  |
|-----------------------------------------------------------------|-------|
| 10.1 WE 32106 MATH ACCELERATION UNIT ASSEMBLY                   |       |
| LANGUAGE INSTRUCTION SET                                        | 10-1  |
| 10.1.1 Programmer's Overview of WE 32106 Math Acceleration Unit | 10-1  |
| MAU Register Support                                            | 10-1  |
| Conditional Jump Instructions                                   | 10-2  |
| MAU Control Bits                                                | 10-2  |
| Immediate Operands                                              | 10-3  |
| 10.1.2 Data Types                                               | 10-3  |
| 10.1.3 MIS Instruction Listings                                 | 10-5  |
| Notation                                                        | 10-5  |
| MIS Instruction Set Descriptions                                | 10-7  |
| MIS Instructions Summary by Function                            | 10-56 |
| MIS Instructions Summary by Mnemonic                            | 10-60 |
| 10.2 FLOATING POINT EMULATION LIBRARY                           | 10-63 |
| 10.2.1 Assembly Language Support                                | 10-63 |
| 10.2.2 Data Type                                                | 10-63 |
| 10.2.3 Floating Point Environment and Exception Handling        | 10-63 |
| 10.2.4 Library Listings                                         | 10-67 |
| Notation                                                        | 10-67 |
| FPE Function Call Descriptions                                  | 10-68 |
| FPE Function Call Summary By Function                           | 10-83 |
| FPE Function Call Summary By Mnemonic                           | 10-84 |
|                                                                 |       |

## APPENDIX A. WE 32100 MICROPROCESSOR INSTRUCTION SET

| A. WE 32100 MICROPROCESSOR INSTRUCTION SET LISTINGS | A-1   |
|-----------------------------------------------------|-------|
| A.1. NOTATION                                       | A-1   |
| A.2. INSTRUCTION SET DESCRIPTIONS                   | A-1   |
| A.3. INSTRUCTION SET SUMMARY BY FUNCTION            | A-93  |
| A.4. INSTRUCTION SET SUMMARY BY MNEMONIC            | A-99  |
| A.5. INSTRUCTION SET SUMMARY BY OPCODE              | A-104 |

## APPENDIX B. IS25 INSTRUCTION SET

| B.          | <b>IS25 INSTRUCT</b> | ION SET | B-1 |
|-------------|----------------------|---------|-----|
| <b>B</b> .1 | . ADDRESSING         | MODES   | B-1 |

| B.1.1 Absolute Mode                            | B-2          |
|------------------------------------------------|--------------|
| B.1.2 Absolute Deferred Mode                   | <b>B-2</b>   |
| B.1.3 Displacement Mode                        | <b>B-2</b>   |
| B.1.4 Displacement Deferred Mode               | <b>B-2</b>   |
| B.1.5 External Address Mode                    | B-3          |
| B.1.6 External Address Deferred Mode           | B-3          |
| B.1.7 Immediate Mode                           | B-3          |
| B.1.8 Register Mode                            | <b>B-3</b>   |
| B.2 JS25 INSTRUCTION SET LISTINGS              | B-4          |
| B.2.1 Notation                                 | B-4          |
| B.2.2 IS25 Instruction Set Descriptions        | B-4          |
| B.2.3 IS25 Instruction Set Summary by Function | <b>B-</b> 59 |
| B.2.4 IS25 Instruction Set Summary by Mnemonic | B-63         |
|                                                |              |

## APPENDIX C. SAMPLE PROGRAMS

| $\cap$     | $\sim$ | 1   |
|------------|--------|-----|
| 6          | - L    | · [ |
| <b>~</b> . | ~      |     |

## GLOSSARY AND ACRONYMS

## INDEX

#### LIST OF FIGURES

| 2-1                                   |
|---------------------------------------|
| 2-2                                   |
| 2-3                                   |
| 2-4                                   |
| 2-4                                   |
| 2-5                                   |
| 4-1                                   |
| 4-1                                   |
| 4-2                                   |
| 4-2                                   |
| 4-3                                   |
| 4-3                                   |
| 4-4                                   |
| 4-4                                   |
| 4-5                                   |
| 5-1                                   |
| 5-2                                   |
| 5-2                                   |
| 5-4                                   |
| 5-5                                   |
| 5-6                                   |
| 5-6                                   |
| 5-7                                   |
| 5-8                                   |
| 5-8                                   |
| 5-9                                   |
| , , , , , , , , , , , , , , , , , , , |

| Figure 5-12. An Absolute Mode Source Operand          | 5-10 |
|-------------------------------------------------------|------|
| Figure 5-13. An Absolute Deferred Mode Source Operand | 5-11 |
| Figure 5-14. Expanded Operand Mode Descriptor Bytes   | 5-11 |
| Figure 5-15. Expanded Operand Mode Example            | 5-12 |
| Figure 6-1. Condition Flags                           | 6-2  |
| Figure 6-2. Stack After CALL-SAVE Sequence            | 6-11 |
| Figure 7-1. Assembly Process                          | 7-2  |
| Figure 7-2. Mapping Program Sections                  | 7-4  |
| Figure 10-1. Bit Order of Data                        | 10-4 |

## LIST OF TABLES

| Table 5-1. Basic Addressing Modes                       | 5-1         |
|---------------------------------------------------------|-------------|
| Table 5-2. The WE 32100 Microprocessor Addressing Modes | 5-2         |
| Table 5-3. Options for type in Expanded Operand Mode    | 5-12        |
| Table 5-4. Addressing Modes                             | 5-14        |
| Table 6-1. Data Transfer Instruction Group              | 6-5         |
| Table 6-2. Arithmetic Instruction Group                 | 6-6         |
| Table 6-3. Logical Instruction Group                    | 6-8         |
| Table 6-4. Program Control Instructions                 | 6-10        |
| Table 6-5. Coprocessor Instructions                     | 6-15        |
| Table 6-6. Stack and Miscellaneous Instructions         | 6-16        |
| Table 6-7. Condition Flag Code Assignments              | 6-16        |
| Table 7-1. as Command Line Options                      | 7-1         |
| Table 7-2. Alphabetical List of Pseudo-Operations       | 7-6         |
| Table 8-1. m32dis Command Line Options                  | 8-1         |
| Table 9-1. Operating System Instructions                | 9-2         |
| Table 10-1. Assembly Language Operators and Symbols     | 10-6        |
| Table 10-2. Floating Point Result Types                 | 10-7        |
| Table 10-3. MIS Instructions Summary by Function        | 10-56       |
| Table 10-4. MIS Instructions Summary by Mnemonic        | 10-60       |
| Table 10-5. FPE Function Call Summary by Function       | 10-83       |
| Table 10-6. FPE Function Call Summary by Mnemonic       | 10-84       |
| Table A-1. Assembly Language Operators and Symbols      | A-2         |
| Table A-2. Register Set                                 | A-3         |
| Table A-3. Data Transfer Instruction Group              | A-93        |
| Table A-4. Arithmetic Instruction Group                 | A-93        |
| Table A-5. Logical Instruction Group                    | A-95        |
| Table A-6. Program Control Instruction Group            | A-96        |
| Table A-7. Coprocessor Instructions                     | A-98        |
| Table A-8. Stack and Miscellaneous Instructions         | A-98        |
| Table A-9. Instruction Set Summary by Mnemonic.         | A-99        |
| Table A-10. Instruction Set Summary by Opcode           | A-104       |
| Table B-1. Addressing Modes for IS25 Instructions       | B-1         |
| Table B-2. Assembly Language Operators and Symbols      | B-5         |
| Table B-3. Data Transfer Instructions                   | B-59        |
| Table B-4. Arithmetic Instructions                      | B-60        |
| Table B-5. Logical Instructions                         | B-61        |
| Table B-6. Program Control Instructions                 | <b>B-62</b> |
| Table B-7. Stack Instructions                           | <b>B-62</b> |
| Table B-8. IS25 Instruction Set Summary by Mnemonic     | B-63        |

•

۰.

Chapter 1 Introduction

## CHAPTER 1. INTRODUCTION

## CONTENTS

| 1.1 OVERVIEW    | ****** | ********** | ******** | •••••• | ······································ |
|-----------------|--------|------------|----------|--------|----------------------------------------|
| 1.2 DEVELOPMENT |        |            |          |        |                                        |
|                 |        |            |          |        |                                        |

#### **1. INTRODUCTION**

This chapter discusses the importance of assembly language programming, introduces the WE 32100 Microprocessor (CPU), and traces its development. An overview of the WE 32100 Microprocessor features is given along with a description of its development from the 8-bit 212 Series Microprocessor to the present 32-bit microprocessors.

#### **1.1 OVERVIEW**

Most programs for AT&T 3B Computers are written in C, a popular high-level programming language which was developed at AT&T Bell Laboratories. Programs MERGE written in C can be highly portable between different computers. Although, in some cases, the C language does not provide easy access to inherently machine dependent operations such as accessing external hardware registers. Often, a piece of software is so frequently used that it is crucial to obtain optimal performance from it. These situations are examples where a programmer should consider writing a program (or subroutine) in WE 32100 Microprocessor (CPU) assembly language for AT&T 3B2/3B5/3B15 Computers.

AT&T has developed a variety of computer products and is constantly enhancing both hardware and software. Each new generation brings with it additional capabilities that users may wish to take advantage of. For example, support of a math coprocessor (WE32106 Math Acceleration Unit, MAU) was added to the WE 32100 CPU. In a few cases, it will be necessary for the assembly language programmer to know which generation of microprocessor (i.e., WE 32001 Processor Module or WE 32100 CPU) is being used on a particular machine. All software that works on the WE 32001 Processor Module will work on the WE 32100 Microprocessor and indicated by the math coprocessor example, the converse is sometimes not true; Programmers can determine which microprocessor and support chips are used on their AT&T computer from their owners' manual or system administrator.

This manual describes the assembly language for the WE 32100 Microprocessor. A short description of earlier version 3B computer assembly language, IS25, which is source compatible with the WE 32100 Microprocessor, is included as a reference. Most programmers should, however, write in native WE 32100 Microprocessor assembly language.

Two methods of performing floating point operations (e.g., add, multiply) are described. One of them, the MAU Instruction Set (MIS), provides optimal floating point performance when it is known that a MAU will always be present in the system. The other method, which performs the operations via function calls, works whether or not a MAU is present.

The WE 32100 Microprocessor is a second-generation device with more speed and processing power than most minicomputers. Using complementary metal oxide semiconductor (CMOS) twin-tub technology, over 180,000 transistors have been placed onto the one-quarter inch silicon square comprising the device.

The CPU's design was based on its immediate predecessor, the 32-bit WE 32001 Processor Module. Both microprocessors have 32-bit data and address buses. The 32-bit data bus allows fetching 32-bits of data in one memory fetch cycle. This significantly reduces memory retrieval time, which is the limiting factor in most microprocessors. The 32-bit address bus allows for a directly addressable 4.3 billion byte address space. Since all onchip registers are also 32-bits wide, 32-bits of data can also be processed in one execution cycle.

Although the WE 32100 Microprocessor is a faster and smaller version of the WE 32001 Processor Module, it is a true second generation 32-bit machine. The WE 32100 Microprocessor has a 64-word, 32-bit high-speed cache memory not available on the earlier processor, improved pipelining capability, and a new I/O controller that supports both distributed processing and coprocessor interfaces. The on-chip instruction cache represents a technological first for any 32-bit processor.

Additionally, both 32-bit processors were designed to be an efficient execution vehicle for the UNIX Operating System and the C programming language. The C compiler and associated software tools make it relatively easy to write optimum code for any application.

#### **1.2 DEVELOPMENT**

The AT&T family of 32-bit processors are direct descendants of the 8-bit 212 Series Microprocessor developed at AT&T Bell Laboratories in the mid-1970s. The 212 Series Microprocessor consisted of 10,000 transistors and performed approximately 200,000 instructions per second using a 3 MHz clock. This 8-bit microprocessor was unique in its use of sixteen general-purpose memory-addressed accumulators and its fabrication in CMOS technology. CMOS, which has since has become the technology of choice for current state-of-the-art microprocessors, was developed early in the 1970s at Bell Laboratories for use in all AT&T microprocessors. CMOS devices use significantly less power than equivalent devices designed in n-channel mos (NMOS), are highly immune to signal interference, and can operate over wide ranges of voltage and temperature. These characteristics are especially important for designing the higher density devices typified by 32-bit microprocessors.

The 212 Series Microprocessor was followed by the single-chip, 4-bit 301 Series Microcomputer. This latter device used 30,000 transistors. The significance of the 301 Series, however, was the introduction and use of AT&T Bell Laboratories internally developed, computer-aided, design technologies in its design and development. The design, development, testing, and introduction of a new microprocessor typically requires two to three years; the computer-aided design and testing cycle developed for the 301 Series would enable the WE 32001 Processor Module to be developed and operational in less than half of that time.

The WE 32001 Processor Module required significantly higher levels of software design, development, and hardware technology than the 301 Series. The design of this first 32-bit microprocessor involved the sophisticated innovations and refinements, in both the CMOS technology and the computer-aided design (CAD) techniques, that were previously used on the 301 Series. As a result, the WE 32001 Processor Module was developed and became successfully operational in thirteen months.

The computer-aided design and development tools used on the WE 32001 Processor Module had an equally significant impact on the introduction of the WE 32100 Microprocessor. The WE 32100 Microprocessor was developed and fabricated in eleven months, with the first device containing only one minor layout error in over 180,000 transistors.

The chapters that follow describe the architecture of the WE 32100 Microprocessor and the assembly language instruction set of the processor as it is used within the 3B family of AT&T computers.



# CHAPTER 2. ARCHITECTURE CONTENTS

| 2. ARCHITECTURE OF THE WE 32100 M | ICROPROCESS | OR                                                                |                              |
|-----------------------------------|-------------|-------------------------------------------------------------------|------------------------------|
| 2.1 ASSEMBLY LEVEL SUPPORT GROUI  | Ρ           |                                                                   | 2-3                          |
| 2.2 HIGH-LEVEL LANGUAGE SUPPORT   | GROUP       |                                                                   |                              |
| 2.3 OPERATING SYSTEM SUPPORT GRO  | OUP         |                                                                   | 2-5                          |
|                                   |             | 에 다 아이지 않는 것이 가지 않는 것이다.<br>같은 사람이 있는 것이 같은 것이 같은 것이 있는 것이 같이 있다. | 일 가지는 거 가에서 수정되는 것을 받는다.<br> |



Figure 2-1. WE 32100 Microprocessor Block Diagram

#### 2. ARCHITECTURE OF THE WE 32100 MICROPROCESSOR

In this chapter we will look at the architecture of the WE 32100 Microprocessor and its internal register set. A block diagram of the WE 32100 Microprocessor illustrating its four major sections: main controller, fetch unit, execute unit, and bus interface control, is shown on Figure 2-1.

The Main Controller is responsible for directing the actions of the Fetch and Execute Controllers as instructions are executed.

The Fetch Unit is responsible for fetching all instructions and data. Although the operation of this unit is transparent to the microprocessor user, it contains unique features which significantly enhance the performance of the WE 32100 Microprocessor. One of these features is a 64-word instruction cache, which stores prefetched instructions from memory. The prefetched instructions are retrieved from memory simultaneous with

#### ARCHITECTURE Architecture of the WE 32100 Microprocessor

instruction execution (a technique known as pipelining). Thus, the normal suspension of execution, while the processor waits for an instruction to be read from memory, is avoided when the next instruction is available in the cache.

The Execution Unit provides all of the features of the microprocessor which are directly user accessible. This unit performs all arithmetic, logical, data-movement, and program control instructions. Contained in the Execution Unit are the sixteen 32-bit user accessible registers, consisting of nine general-purpose registers (r0-r8), and seven special-purpose registers (r9-r15).

In addition to supporting an extremely powerful assembly language, the registers in the WE 32100 Microprocessor were also designed for the efficient support of procedureoriented high level languages, such as C, and process-oriented operating systems, such as the UNIX Operating System.

Although all of the sixteen registers are available to assembly language programmers, it is useful to separate the register set into three groups: the Assembly Level support group, the High-Level Language support group, and the Operating System support group. These groups are illustrated on Figure 2-2.



Figure 2-2. The WE 32100 Microprocessor Register Set





#### 2.1 ASSEMBLY LEVEL SUPPORT GROUP

The assembly level support registers consist of nine general-purpose registers, a stack pointer, and a program counter. This set of registers, including condition flags, is typically associated with an assembly language programming model of a microprocessor. In the WE 32100 Microprocessor the condition flags, which are indicators of the processor's current status, are contained within the processor status word register.

The nine general-purpose registers are referred to as r0 through r8, respectively. These registers can be used with all arithmetic, data transfer, logical, and program control assembly instructions. Additionally, registers r0, r1, and r2 are used in both string manipulation and transfer instructions and, by convention, for returning values from a called C language program. The string manipulation and transfer instructions that use registers r0, r1, and r2 include the block move (MOVBLW), string copy (STRCPY), and string end (STREND) instructions (see 6. Instruction Set).

The Stack Pointer (SP), r12, contains the current 32-bit address of the top of the current execution stack. As illustrated on Figure 2-4, the stack pointer points to the next available memory location that can be used. A PUSH instruction immediately stores its operand at the current memory address contained in the stack pointer. The stack pointer is then incremented by the site of the PUSHed operand. Thus, the stack "grows" into increasing memory address space. A POP instruction first decrements the stack pointer by the site of the POPed operand (to point to the last pushed operand) and then fetches the data from the top of the stack.

The *Program Counter* (PC), r15, contains the 32-bit memory address of the currently executing instruction or, upon completion, the starting address of the next instruction to be executed. The PC is referenced by all program control instructions and all function calls and returns.



Figure 2-4. The WE 32100 Microprocessor Stack

#### 2.2 HIGH-LEVEL LANGUAGE SUPPORT GROUP

The Frame Pointer and Argument Pointer constitute the high-level language support group register set. Although these two registers may be accessed and used as general-purpose assembler registers, they are typically used in association with registers r0, r1, and r2 for passing, holding, and returning high-level language variables and arguments.

These registers perform the following functions:

The *Frame Pointer* (FP), r9, points to the beginning location in the stack where the local variables of the currently running program, procedure, or function are stored. The frame pointer is implicitly changed by the save registers (SAVE) and restore registers (RESTORE) assembly instructions.

The Argument Pointer (AP), r10, points to the beginning location in the stack where arguments passed into the currently running program, procedure, or function have been pushed. The ap is implicitly affected by procedure call (CALL) and return (RET) assembly instructions.



Figure 2-5. High-Level Language Register Support Group

#### 2.3 OPERATING SYSTEM SUPPORT GROUP

The Processor Status Word, Process Control Block Pointer, and Interrupt Stack Pointer were designed to facilitate an efficient operating system interface. These three registers, therefore, are referred to as the operating system support group.

The three registers forming this group perform the following functions:

The Processor Status Word (PSW), r11, contains status information about the microprocessor and the current process. Additionally, the PSW contains four condition code flags used by assembly language transfer-of-control instructions. In general, the PSW changes as a whole only when a process switch occurs and can only be written in an operating system mode.

The *Process Control Block Pointer* (PCBP), r13, points to the starting address of the process control block for the current process. The process control block is a data structure in external memory that contains the hardware context of a process when the process is not running. This context consists of the initial and current contents of the processor status word, program counter, and stack pointer; the last contents of registers r0 through r10; boundaries for an execution stack; and block move specifications (and possibly memory specifications) for the process. The PCBP may only be written when the microprocessor is in an operating system mode.

The Interrupt Stack Pointer (ISP), r14, contains the 32-bit memory address of the top of the interrupt stack. This stack is used when an interrupt request is received and also by the call process (CALLPS) and return to process (RETPS) instructions. The ISP may only be written when the microprocessor is in an operating system mode.



Figure 2-6. Operating System Register Support Group

## Chapter 3 Assembly Language Structure

## CHAPTER 3. ASSEMBLY LANGUAGE STRUCTURE

## CONTENTS

| 3. ASSEMBLY LANGUAGE STRUCTURE              |  |
|---------------------------------------------|--|
| 3.1 STATEMENTS                              |  |
| 3.2 EXECUTABLE INSTRUCTIONS                 |  |
| 3.3 SYMBOLS                                 |  |
| 3.3.1 Values and Types                      |  |
| 3.3.2 Assigning Values and Types to Symbols |  |
| 3.4 EXPRESSIONS                             |  |
| 3.4.1 Constants                             |  |
| 3.4.2 Registers                             |  |

#### 3. ASSEMBLY LANGUAGE STRUCTURE

This chapter describes the assembly language, syntax, and semantics supported by the assembler (as) provided for the 3B2/3B5/3B15 Computers. All 3B2/3B5/3B15 Computers have the same basic instruction set. But, some models have additional instructions due to the advanced features of the WE 32100 Microprocessor architecture. Therefore, the discussion on the microprocessor instruction set will be based on the WE 32100 Microprocessor instruction set. Contained in Appendix C are some assembly language programming examples which conform to the syntax and semantics described in this chapter.

The basic actions of evaluation, assignment, and control of evaluation order are specified by statements. Statements are either microprocessor instructions, assembler directives, or IS25 instructions.

The data types supported by the assembly language are byte, halfword, word, single, double, double extended, and bit field. A byte is an 8-bit quantity; a halfword is a 16-bit quantity; a word is a 32-bit quantity; a single is a 32-bit floating point quantity; a double is a 64-bit floating point quantity; a double extended is a 96-bit floating point quantity; and a bit field is a sequence of 1 to 32 bits. Detailed information on the data types can be found in 4. Data Organization.

The instruction set provides that bytes, halfwords, words, singles, doubles, and double extendeds can be interpreted as either signed or unsigned quantities for arithmetic or logical operations.

#### 3.1 STATEMENTS

An assembly language program consists of a sequence of lines of code. Each line consists of a sequence of characters terminated by the new-line character (n), which is equivalent to control -J (line-feed). Each line may contain one or more statements. If several statements appear on a line, they must be separated by semicolons (;). Each statement must be one of the following:

- Assembler Directive a statement that is a command to the assembler. It consists of a pseudo-operation code followed by zero or more operands. Assembler Directives are discussed in detail in 7.3 Assembler Directives.
- WE 32100 Microprocessor Instruction a mnemonic representation of an executable machine instruction. It consists of an operation code followed by zero or more operands. WE 32100 Microprocessor instructions are discussed in detail in Appendix A.
- IS25 Instruction a statement that maps into one or more executable microprocessor instructions. IS25 instructions are discussed in detail in Appendix B.
- Empty a statement that contains only spaces, tabs, or a comment. It signifies nothing to the assembler, but is often used to enhance program readability.
- Operation codes (or mnemonics) are separated from their operands by at least one space or tab. Operands and arguments are separated by commas. Unless otherwise stated, any other use of space and tab characters is optional. White space characters may be used freely to improve readability.

In the order shown, each nonempty line of code is made up by one or more of the following:

- A label may be placed on any statement. The label consists of a symbol that begins in the first character position of a statement (i.e., it must begin IMMEDIATELY after a new-line character or semicolon) and is followed by a colon. Symbols are described in detail in 3.3 Symbols. An unlabeled statement MUST have a space, tab, or pound sign (#) in the first character position.
- A mnemonic may be placed on any statement. The mnemonic consists of a *symbol* that begins after any white space at the beginning of a statement or after a label. The mnemonic defines an assembler directive or a machine operation (either processor or IS25 instruction).
- One or more operands may be placed on a statement containing a mnemonic. An operand, in the case of a machine instruction, defines the addressing modes of source and destination operands. These type of operands are further discussed in 4.1 Data Types and 5. Addressing Modes. Operands supplied with an assembler directive are used by the assembler to execute the command issued by the assembler directive. These operands are discussed in 7.3 Assembler Directives.
- A comment may be inserted at the end of any statement by preceding the comment with a pound sign (#) or may be on a line by itself by inserting a pound sign in the first character position. The assembler will ignore the pound sign and all characters following it up to the first new-line character. A new statement begins with the first character after the new-line character.

There are no limits on the number of characters in a statement or on the number of statements on a line. Multiline comments are made by inserting a pound sign as the first nonwhite-space character of each line.

An example showing the four parts of assembly language line follows. The first statement shows an assembler directive. The second statement is empty and was inserted to provide a visual break between directive and machine-instruction sections. The last two statements are an IS25 and processor instruction, respectively.



#### 3.2 EXECUTABLE INSTRUCTIONS

Mnemonics for processor instructions use uppercase letters and IS25 instruction mnemonics use lowercase letters, When coding in assembly language, this distinction must be maintained. Therefore, all machine-specific mnemonics *must* be coded in uppercase, while mnemonics common to the IS25 instructions must be coded in lowercase. Be careful when switching between processor and IS25 instructions. Although the mnemonics are identical in many cases, the operations are not. For example, the IS25 instruction cmpw &1,&2 will set the less-than flag, while the processor instruction CMPW &1,&2 would, under the same conditions, set the greater-than flag, because the operand order is reversed.

The processor instruction set is more complete and often faster than the IS25 instruction set. IS25 instructions can be portable to earlier version 3B computers, while processor instructions can not.

• .

#### 3.3 SYMBOLS

Symbols are names recognized by the assembler. They always have a value and type, either specified explicitly by an assignment statement (see 7.3 Assembler Directives) or determined from the context. Value and type are described in detail in this section. A symbol name consists of a string of the characters a-z, A-Z, 0-9, underscore (), and period (.). Names may not begin with a digit. Because embedded blanks are not permitted in symbols, the underscore is generally used in place of a blank to make an identifier more readable.

Symbols are used as labels, mnemonics, or operands (in some cases). Four examples of symbols are:

Rtn\_Nam5 abc DEF xyz.QQQ.

The assembler does not put symbols beginning with . (read as 'dot') into the object file symbol table. Exceptions to this rule are .text, .data, and .bss; these symbols are used for relocation.

The following symbols are reserved for use by the assembler:

- 1. This symbol (read as dot) is used as the location counter while assembling a program. Whenever actual code is generated by the assembler, the value of this symbol is increased by the size of the generated code. Hence, this symbol effectively represents the address of the code being generated. Depending on the section for which code is being generated, dot may be of type TEXT, DATA, or BSS. Null data can be generated by pseudo-op assignment to this symbol.
- 2. .text This symbol has type TEXT and is used to label the beginning of the .text section for the program being assembled. The .text section contains executable instructions.
- 3. .data This symbol has type DATA and is used to label the beginning of the .data section for the program being assembled. The .data section contains initialized variables.
- 4. .bss This symbol has type BSS and is used to label the beginning of the .bss section for the program being assembled. The .bss section contains uninitialized variables.

#### **3.3.1** Values and Types

Values are represented in the assembler by signed 32-bit 2's complement numbers. Every value is an instance of one of the following types:

| TEXT | A TEXT value is one that is defined relative to the beginning of the .text |
|------|----------------------------------------------------------------------------|
|      | section. Whenever the .text section is relocated forward (backward) by N   |
|      | bytes, the number N will be added to (subtracted from) every value of      |
| ÷    | type TEXT. The most common example of a TEXT value is a label              |
|      | appearing in the .text section.                                            |

- DATA A DATA value is one that is defined relative to the beginning of the .data section. Whenever the .data section is relocated forward (backward) by N bytes, the number N will be added to (subtracted from) every value of type DATA. The most common example of a DATA value is a label appearing in the .data section.
- BSS A BSS value is one that is defined relative to the beginning of the .bss section. Whenever the .bss section is relocated forward (backward) by N bytes, the number N will be added to (subtracted from) every value of type BSS.
- UNDEFINED An UNDEFINED value is one whose type has not yet been determined. The UNDEFINED value may be a reference to a symbol whose definition has not been encountered yet (i.e., a forward reference) or a reference to a symbol that is assumed to be defined in a file or module other than the one currently being assembled (i.e., an external reference).
- ABSOLUTE An ABSOLUTE value is one that will not change as a result of relocating any section of the program being assembled. Constants described in the following section have absolute type.

In addition, any of the above types may be given the attribute EXTERNAL. For values of the types ABSOLUTE, TEXT, DATA, and BSS, the attribute EXTERNAL indicates that a value defined in the program currently being assembled will be made available to other programs. For values of type UNDEFINED, EXTERNAL means that the value is referenced in the file or module currently being assembled, but is defined in some other program.

۰.

#### 3.3.2 Assigning Values and Types to Symbols

There are two ways to assign a value and a type to a symbol. The first is to write the symbol as a label. The label will be assigned the current value and type of the location counter. The second is through the use of the .set assembler directive (see 7.3.3 Assignment Pseudo Operations). An arbitrary value and type can be assigned with this directive.

#### ASSEMBLY LANGUAGE STRUCTURE Expressions

#### 3.4 EXPRESSIONS

An expression is a sequence of operands separated by operators. An operand is either a constant, a symbol, or an expression enclosed in parentheses.

Expressions can be used as operands either to assembler directives or to machine instructions, as maybe appropriate. All operators are fundamentally binary in nature. The operator "-" may be used as a unary operator with the interpretation 0-. For example, -x is interpreted as (0-x).

All operators are assumed to be of EQUAL precedence. If anything other than left-toright evaluation is desired, parentheses must be used for grouping.

If, in the process of evaluating an expression, an intermediate result will not fit in 32 bits, the final value of that expression will be undefined.

The following operators are available:

- + Produces the 2's complement sum of its operands. One operand *must* be type ABSOLUTE - the other can be any type. The sum has the type of the other operand. All other combinations of operands are illegal.
- Produces the 2's complement result of subtracting the right operand from the left operand. If the right operand is ABSOLUTE, the difference has the type of the left operand. Otherwise, both operands must be of the same type (which cannot be UNDEFINED) and the result has type ABSOLUTE. All other combinations of operands are illegal.

The result of the subtraction can be erroneous when taking the difference between two relocatable symbols. For example, the value of lab1-lab2, where lab1 and lab2 are labels that are both of type TEXT, DATA, or BSS, may change due to various optimizations of the code between lab1 and lab2 that are made after the assignment of values and types to lab1 and lab2. In such cases, the value of lab1-lab2 will not correctly indicate the difference in address between lab1 and lab2.

- \* Produces the 2's complement product of its operands. It requires both operands to be of ABSOLUTE type and produces an ABSOLUTE result.
- / Produces the 2's complement quotient of the left operand divided by the right operand. Uneven divisions result in the integer that is the result of truncating the quotient toward zero; for example, 5/-2 = -2. The quotient operator requires both operands to be of ABSOLUTE type and produces an ABSOLUTE result.

#### 3.4.1 Constants

1 2 3

A constant is an object of ABSOLUTE type and fixed value. The size and appropriate number of digits are controlled by the generation of pseudo-ops .byte, .half, and .word. A constant may be one of the following:

• A decimal constant is represented by a contiguous string of the digits 0-9, beginning with a nonzero digit. Examples of decimal constants are:

123 75 1943 2

• An octal constant is represented by a contiguous string of the digits 0-7 beginning with a zero digit. Examples of octal constants are:

077 0123 06 03777777777

• A hexadecimal constant is represented by a contiguous string of the digits 0-9 and the letters a-f or A-F, prefixed by 0x or 0X. Examples of hexadecimal constants are:

0x3f 0X9aC 0xabcd 0XFE

In order to be recognized as floating point, a constant must contain either a decimal point or one of the exponential characters (e or E). Floating point constants that cannot be encoded exactly in the specified form are rounded off.

Examples of floating point data types are:

31.0500 -16. 0.1024e4 500e-3

Floating point data specifications are to conform to the IEEE standard for binary floatingpoint arithmetic.

#### 3.4.2 Registers

Registers 3 through 8, which are referred to by the assembly language syntax %r3, %r4, %r5, ..., %r8, are the general-purpose registers that are always available to the programmer. Registers 0, 1, and 2 are considered general-purpose, but have implicit definitions because of certain conventions of the C language. For example, r0 should always be used to return the value of a function. If a floating point double value is returned from a function, it is stored in r0 and r1. If a function returns a structure, then the pointer to that structure should be returned to r2. In general, r0, r1, and r2 are scratch registers.

Registers 9 (frame pointer), 10 (argument pointer), and 12 (stack pointer) are also implicitly used, in this case by call and return instructions. These registers can be referred to by the assembly language syntax %fp, %ap, and %sp, respectively. Registers 0, 1, 2, 9, 10, and 12 may be used in any addressing mode, privileged or nonprivileged. The use of r0, r1, and r2 for function calls and returns is described in **5.2.2 Function Calling Sequence**.

The program counter, PC, (r15) is a special register that does not work in all addressing modes. The three registers not yet discussed are privileged and any attempt to write them when the processor is not at kernel execution level results in a privileged register exception. These three registers are the interrupt stack pointer (ISP), the process control block pointer (PCBP), and the process status word (PSW).

The PSW (r11) contains four condition bits -N, Z, V, and C. Because of the pipelining architecture of the processor, the condition codes in the PSW may not be valid immediately after the execution of an instruction. This inherent delay is not problematic for any conditional branch instructions; the instructions wait until the condition codes are valid before they are then tested.



## CHAPTER 4. DATA ORGANIZATION

## CONTENTS

| 4. DATA ORGANIZATION       | 4-1    |
|----------------------------|--------|
| 4.1 DATA TYPES             |        |
| 4.2 DATA STORAGE IN MEMORY | Y 4-3  |
| 4.3 REGISTER DATA STORAGE  |        |
| 4.4 INSTRUCTION STORAGE IN | MEMORY |
# 4. DATA ORGANIZATION

This chapter describes the data types, data organization, and data storage supported by the WE 32100 Microprocessor.

# 4.1 DATA TYPES

The data types supported by the WE 32100 Microprocessor are byte, halfword, word, floating point (word, double word, and double extended word), and bit field data. The instruction set provides that bytes, halfwords, and words can be interpreted as either signed or unsigned quantities.

A byte is an 8-bit quantity that may appear at any address. Bits are numbered from right to left within a byte, starting with zero, the least significant bit (LSB), and ending with 7, the most significant bit (MSB), as illustrated on figure 4-1.

A *halfword* is a 16-bit quantity that may appear at any address divisible by two. Bits are numbered from right to left starting with zero, the LSB, as illustrated on Figure 4-2.

A word is a 32-bit quantity. Data words may appear at any address divisible by four. Bits are numbered right to left starting with zero, the LSB, as illustrated on Figure 4-3.

Floating Point data types may appear at any address in memory divisible by four. Figure 4-4 illustrates the floating point data types supported by the assembler.



Figure 4-1. Byte Data



Figure 4-2. Halfword Data



Figure 4-3. Word Data

Each of these four data types may be interpreted as either a signed or unsigned quantity, with signed data represented in 2's complement form.

A bit field is a sequence of 1 to 32 bits extracted from a byte, halfword, or a word. The bit field is determined from the address of the word containing the field, an offset, and a width. The offset, from 0 to 31, identifies the starting bit in the word containing the bit field. This bit becomes the least significant bit of the selected field. The width, a number from 0 to 31 specifies the size of the field. The number of bits in the extracted field is one more than the width value. Figure 4-5 illustrates a bit field extracted from a word using an offset of six and a width of nine. Notice that the extracted field contains ten bits, one more than the width.

Bit fields do not extend across word boundaries. If the selected width requires bits beyond the most significant bit of the word being used, the extraction of bits continues by wrapping around to the least significant word bits.

| Bit   | 31   | 30       | 23 | 22   | 0    |
|-------|------|----------|----|------|------|
| Field | Sign | Exponent |    | Frac | tion |

#### A. Single Precision Floating Point Data Type

| Bit   | 63   | 62       | 52 | 51   | 0    |
|-------|------|----------|----|------|------|
| Field | Sign | Exponent |    | Frac | tion |

#### **B.** Double Precision Floating Point Data Type

| Bit   | 85  | 80   | 79   | 78   | 64    | 63 | 62   | 0    |
|-------|-----|------|------|------|-------|----|------|------|
| Field | Uni | ised | Sign | Expo | onent | J  | Frac | tion |

#### C. Double Extended Floating Point Data Type

#### Figure 4-4. Floating Point Data Types



Figure 4-5. Extraction of a Bit Field

#### 4.2 DATA STORAGE IN MEMORY

Figure 4-6 illustrates the storage of word data in memory. As illustrated, the word 0x12345678 is stored with the lower-order bytes at higher-order addresses. All data stored in memory follows this format. For example, the halfword data 0xEEFF would be stored in memory with the lower-order byte, 0xFF, at the next higher-byte address than the location containing the byte 0xEE.

#### 4.3 REGISTER DATA STORAGE

All data stored in a register is a full 32 bits, regardless of the instruction or data type. For all CPU operations, including register storage, the WE 32100 Microprocessor reads in the correct number of bits for the operand and extends the data automatically to 32 bits. Halfword operands and signed data are sign extended to 32 bits. In sign extension, the value of the most significant bit is replicated to fill the high-order bits. When storing byte operands or unsigned data into a register, zero extension is used. In zero extension, the high-order bits are filled with zeros.



Figure 4-6. Word Storage in Memory

Intermediate results of all operations in the CPU are always 32 bits. If the results of an operation are stored in a register, the processor writes all 32 bits to the register.

When a register is specified as the source of a byte operand, the low-order 8 bits (bits 0-7) of the register are fetched and zero extended to 32 bits. The zero extension may be

changed to a sign extension using an expanded operand type addressing mode (this addressing mode is described in 5. Addressing Mode). When a register is used as the source of a halfword operand, the low-order 16 bits (bits 0-15) of the register are fetched and sign extended to 32 bits. Again, the type of extension may be changed to zero extension using an expanded operand type addressing mode.

#### 4.4 INSTRUCTION STORAGE IN MEMORY

Instructions may appear at any byte address in memory, and are stored as a one- or twobyte opcode followed by up to four operands. Figure 4-7 illustrates the general format of an assembly instruction as it is stored in memory. Each individual operand shown on Figure 4-7 consists of a descriptor byte, followed by up to four bytes of data (see Figure 4-8).

The descriptor byte defines an operand's addressing mode and register fields, which are covered in the next chapter. Immediate data stored within an instruction is stored with lower-order bytes located at lower-order addresses. For example, the value 0x12345678 would be stored within an instruction as illustrated on Figure 4-9.



Figure 4-7. Instruction Storage in Memory

INCREASING MEMORY ADDRESSES



Figure 4-8. Operand Format

#### INCREASING MEMORY ADDRESSES

T. 11



Figure 4-9. Word Storage Within an Instruction

Notice that the storage of data within an instruction, as shown on Figure 4-9, is the reverse of the storage of data within a memory location as illustrated on Figure 4-6.

# Chapter 5 Addressing Modes

# CHAPTER 5. ADDRESSING MODES

# CONTENTS

ISAN BUT LEVER STREET STATES IN THE REPORT

| <ul> <li>5.1 REGISTER MODE</li> <li>5.2 REGISTER DEFERRED MODE</li> <li>5.3 DISPLACEMENT MODE</li> <li>5.4 DEFERRED DISPLACEMENT MODE</li> <li>5.5 IMMEDIATE MODE</li> <li>5.6 ABSOLUTE MODE</li> <li>5.7 ABSOLUTE DEFERRED MODE</li> <li>5.8 EXPANDED OPERAND MODE</li> <li>5.9 SUMMARY</li> </ul> | 5. ADDRESSING MODES            |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|--|
| <ul> <li>5.2 REGISTER DEFERRED MODE</li></ul>                                                                                                                                                                                                                                                       | 5.1 REGISTER MODE              |  |
| <ul> <li>5.3 DISPLACEMENT MODE</li></ul>                                                                                                                                                                                                                                                            | 5.2 REGISTER DEFERRED MODE     |  |
| <ul> <li>5.4 DEFERRED DISPLACEMENT MODE</li></ul>                                                                                                                                                                                                                                                   | 5.3 DISPLACEMENT MODE          |  |
| <ul> <li>5.5 IMMEDIATE MODE</li></ul>                                                                                                                                                                                                                                                               | 5.4 DEFERRED DISPLACEMENT MODE |  |
| <ul> <li>5.6 ABSOLUTE MODE</li></ul>                                                                                                                                                                                                                                                                | 5.5 IMMEDIATE MODE             |  |
| <ul> <li>5.7 ABSOLUTE DEFERRED MODE</li> <li>5.8 EXPANDED OPERAND MODE</li> <li>5.9 SUMMARY</li> </ul>                                                                                                                                                                                              | 5.6 ABSOLUTE MODE              |  |
| 5.8 EXPANDED OPERAND MODE                                                                                                                                                                                                                                                                           | 5.7 ABSOLUTE DEFERRED MODE     |  |
| 59 SUMMARY                                                                                                                                                                                                                                                                                          | 5.8 EXPANDED OPERAND MODE      |  |
|                                                                                                                                                                                                                                                                                                     | 5.9 SUMMARY                    |  |

# 5. ADDRESSING MODES

In this chapter, we will look at addressing modes for the WE 32100 Microprocessor, their assembly language coding, and their storage in memory.

An assembly language instruction for the WE 32100 Microprocessor consists of a mnemonic, such as ADDW, MOVH, INCB, followed by up to four operands. Each operand is physically located as immediate data in either one of the microprocessor's registers, a memory location, an input-output port, or directly within the instruction. The operand written in the assembly language instruction must provide sufficient information for the actual operand to be located by the microprocessor. The information provided by the assembly language instruction to specify an operand's address is called addressing mode data.

Table 5-1 provides a partial listing of the microprocessor's basic addressing modes. A complete description of addressing modes is presented in Table 5-2.

| Table 5-1. Basic Addressing Modes |             |           |  |  |  |  |  |
|-----------------------------------|-------------|-----------|--|--|--|--|--|
| Mode Syntax Example               |             |           |  |  |  |  |  |
| Register                          | %reg        | %r2       |  |  |  |  |  |
| Register Deferred                 | (%reg)      | (%r2)     |  |  |  |  |  |
| Register Displacement             | expr(%reg)  | 6(%r2)    |  |  |  |  |  |
| Register Displacement Deferred    | *expr(%reg) | *6(%r2)   |  |  |  |  |  |
| Immediate                         | &expr       | &0x1234   |  |  |  |  |  |
| Absolute                          | \$expr      | \$0x2E54  |  |  |  |  |  |
| Absolute Deferred                 | *\$expr     | *\$0x2E54 |  |  |  |  |  |

Notes:

- 1. reg represents one of the microprocessor's registers (r0-r15).
- 2. expr is an expression that evaluates to either a byte, halfword, or word value.

An assembly language instruction is stored in memory as a one- or two-byte opcode followed by up to four operands. Figure 5-1 illustrates the memory storage format of an assembly instruction previously described in Chapter 4. Recall that each operand shown in Figure 5-1 consists of a descriptor byte, followed by up to four bytes of data (see Figure 5-2).

#### INCREASING MEMORY ADDRESSES



Figure 5-1. Instruction Format

The descriptor byte defines an operand's addressing mode and register field. Figure 5-3 illustrates the format of the descriptor byte, which consists of two 4-bit fields.

「「「「「「「「」」」」

The register field, denoted as rrrr, consists of bits 0 through 3 of the descriptor byte, and contains the number of a register, 0 through 15. The mode field, denoted as mmmm, consists of the four higher-order bits of the descriptor byte, bits 4 through 7. This field contains an address mode number, 0 through 15. Table 5-2 lists all mode field values (0-15) and their corresponding addressing modes.



INCREASING MEMORY ADDRESSES

Figure 5-2. Operand Format

| 7 | 4              | 3 0               |
|---|----------------|-------------------|
|   | ՠՠՠՠ           | rrrr              |
|   | MODE<br>FIEL D | REGISTER<br>FIELD |

Figure 5-3. Descriptor Byte Format

| Т                      | Table 5-2. The WE 32100 Microprocessor Addressing Modes |                                                                                                                                                                                                                                                                                 |  |  |  |
|------------------------|---------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Mode<br>Field<br>Value | Addressing<br>Mode                                      | Description                                                                                                                                                                                                                                                                     |  |  |  |
| 0-3                    | Literal                                                 | The register field bits are concatenated with<br>the two low-order mode field bits to form an<br>unsigned 6-bit immediate data.                                                                                                                                                 |  |  |  |
| 4                      | Register                                                | The operand is contained in one of the 16<br>registers. If register 15 is specified in the<br>register field, this becomes the word<br>immediate mode.                                                                                                                          |  |  |  |
| 5                      | Register<br>Deferred                                    | The register specified in the register field<br>contains the operand's address. If register 15<br>is specified in the register field, this becomes<br>the halfword immediate mode.                                                                                              |  |  |  |
| 6                      | FP Short Offset                                         | The FP (register 9) is implicitly referred to<br>by this mode. Register field bits are used as<br>an offset and are added to the FP to form the<br>operand's address. This addressing mode is<br>an optimized case of the register deferred<br>mode, produced by the assembler. |  |  |  |

| Table 5-2. The WE 32100 Microprocessor Addressing Modes (Continued) |                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
|---------------------------------------------------------------------|--------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Mode<br>Field<br>Value                                              | Addressing<br>Mode                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| 7                                                                   | AP Short Offset                      | The AP (register 10) is implicitly referred to by this<br>mode. Register field bits are used as an offset and<br>are added to the AP to form the operand's address.<br>If register 15 is specified by the register field, this<br>mode becomes the absolute mode. The four bytes<br>following the descriptor byte contain the operand's<br>address. This addressing mode is an optimized case<br>of the register deferred mode, produced by the<br>assembler. |  |  |
| 8                                                                   | Word<br>Displacement                 | The four bytes following the descriptor byte are<br>added to the contents of the register specified in the<br>register field. The sum forms the address of the<br>operand.                                                                                                                                                                                                                                                                                    |  |  |
| 9                                                                   | Word<br>Displacement<br>Deferred     | The four bytes following the descriptor byte are<br>added to the contents of the register specified in the<br>register field. The sum forms the address of a<br>pointer. The operand's address is contained within<br>the pointer.                                                                                                                                                                                                                            |  |  |
| A                                                                   | Halfword<br>Displacement             | The two bytes following the descriptor byte are<br>added to the contents of the register specified in the<br>register field to form the operand's address.                                                                                                                                                                                                                                                                                                    |  |  |
| В                                                                   | Halfword<br>Displacement<br>Deferred | The two bytes following the descriptor byte are<br>added to the contents of the register specified in the<br>register field. The sum forms the address of a<br>pointer. The operand's address is contained within<br>the pointer.                                                                                                                                                                                                                             |  |  |
| С                                                                   | Byte<br>Displacement                 | The byte following the descriptor byte is added to<br>the contents of the register specified in the register<br>field to form the operand's address.                                                                                                                                                                                                                                                                                                          |  |  |
| D                                                                   | Byte<br>Displacement<br>Deferred     | The byte following the descriptor byte is added to<br>the contents of the register specified in the register<br>field. The sum forms the address of a pointer. The<br>operand's address is contained within the pointer.                                                                                                                                                                                                                                      |  |  |
| E                                                                   | Expanded<br>Operand                  | This mode is used to modify the data type of an operand. If register 15 is specified in the register field, this becomes the absolute deferred mode.                                                                                                                                                                                                                                                                                                          |  |  |
| F                                                                   | Negative Literal                     | The register field bits are concatenated with the mode field bits to form a negative literal, in the range $-1$ to $-16$ .                                                                                                                                                                                                                                                                                                                                    |  |  |

1.2.04 m

We will now consider each of the microprocessor's addressing modes and see how they are coded within an operand's descriptor byte. It should be noted that certain branch instructions, and all coprocessor words do not require addressing mode information and therefore do not use a descriptor byte. 「「「「「「「「「」」」」

#### 5.1 REGISTER MODE

Any operand directly located in one of the microprocessor's registers is accessed using the register address mode. This mode is indicated in assembly language with the percent symbol (%).

For example, the instruction INCW % r2 causes the 32-bit contents of register r2 to be incremented by one.

The general syntax, mode, and register fields used to signify the register addressing mode are:

syntax: % rn where n is a register number mmmm: 4 rrrr: 0 to 14

Thus, the instruction INCW % r2 is stored in memory as illustrated on Figure 5-4.



Figure 5-4. Register Mode Example

# 5.2 REGISTER DEFERRED MODE

Deferred addressing mode involves indirect addressing using pointers. A pointer is either a register or memory location containing an address. Figure 5-5 illustrates the relationship between the address contained in a pointer and the operand ultimately obtained. The term *deferred* is used to describe this procedure because the operand finally obtained is deferred, or delayed, by first going to the pointer for an address. The address contained in the pointer is then used to access the desired operand.

When deferred addressing is used and the pointer is one of the microprocessor's registers, the addressing mode is referred to as a register deferred mode. This addressing mode is designated in assembly language by using parentheses around the pointer register.

For example, the instruction MOVW (% r2),% r3 causes the CPU to regard the data in register r2 as an address. The contents of the memory location having this address will be copied into register r3. Notice that this instruction uses two operands and each operand has its own addressing mode. Although a register deferred mode was used for the source operand and a register mode was used for the destination operand, any other valid addressing modes could have been used.

The general syntax, mode, and register fields for a register deferred mode operand are:

syntax: (% rn) where n is a register number mmmm:5 rrrr: 0 to 10, 12 to 14

Using this information, the instruction MOVW (% r2),% r3 is stored in memory as shown on Figure 5-6.



Figure 5-5. Deferred Addressing Using a Pointer



Figure 5-6. Register Deferred Mode Example

# 5.3 DISPLACEMENT MODE

The displacement mode forms an operand's address by adding an offset to the contents of a WE 32100 Microprocessor register. For example, the instruction MOVW 0x30(% r2),% r3 copies the contents of a memory location into register r3. The source operand's memory address is calculated as the contents of register r2 plus an offset of 0x30. Figure 5-7 illustrates the result of this MOVW instruction.



Figure 5-7. Example of MOVW 0x30(% r2),% r3

The general syntax, and valid register fields for a displacement mode operand are:

| syntax: offset(% rn)    | where n is a register number     |
|-------------------------|----------------------------------|
| mmmm: 8, 10, or 12      | (word, halfword, or byte offset) |
| rrrr: 0 to 10, 12 to 15 |                                  |

Using the appropriate mode and register fields, the instruction MOVB 0x30(% r2),% r3 is stored in memory as shown on Figure 5-8.

The offset used in the displacement mode may be either a byte (8-bits), halfword (16-bits), or word (32-bits), or an expression yielding such a value. 2's complement, negative offsets are also valid. Negative byte and halfword offsets are first sign-extended to 32 bits before being used to obtain the operand's final address. This sign extension converts a negative byte or halfword into its equivalent 32-bit counterpart.

When the displacement mode is used with registers FP (frame pointer) and AP (argument pointer), only a short offset between 0 and 14 may be used. This facilitates storage of a shortened instruction format in memory. The mode fields, when the frame and argument registers are used in the displacement mode, are 6 and 7, respectively. The short offset (0-14) is stored in the register field and extra bytes for an offset are not included in the stored instruction.



Figure 5-8. A Displacement Mode Source Operand



Figure 5-9. Deferred Displacement Addressing

## 5.4 DEFERRED DISPLACEMENT MODE

The deferred displacement mode uses the contents of the address calculated in the displacement mode as a pointer to the desired operand. Consider the example shown on Figure 5-9. For a typical displacement mode, the operand would be located in the first memory address calculated. In deferred displacement mode, the contents of this location are used as the address of the desired operand.

The deferred displacement mode is indicated to the assembler by the use of an asterisk before the offset.

For example, the instruction INCW \*0x30(% r2) adds one to the contents of a memory location whose address is contained within a pointer. The address of the pointer is the contents of register r2 plus 0x30.

The general syntax, mode field, and register field for a deferred displacement mode operand is:

syntax: \*expr(% rn)mmmm: 9, 11, or 13 (word, halfword, or byte offset) rrrr: 0-10, or 12-15

Using this information, the instruction MOVB \*0x30(% r2),% r3 is stored in memory as illustrated on Figure 5-10.



#### INCREASING MEMORY ADDRESSES

Figure 5-10. A Deferred Displacement Mode Source Operand

# 5.5 IMMEDIATE MODE

In the immediate addressing mode, the operand is contained within the instruction. The ampersand symbol is used to indicate this addressing mode to the assembler.

For example, the instruction MOVB &0x50,% r6 copies the immediate data, 0x50, into register r6. The & symbol signifies that the data immediately following is to be treated as immediate data. The % symbol, as should now be familiar, indicates that the register mode is being used for the destination operand.

The general syntax, valid mode and register fields for the immediate addressing mode are:

*syntax*: &data (data = 8-, 16-, or 32-bits) mmmm: 4, 5, or 6 rrrr: 15

A mode field of 4 indicates that the immediate data is 32-bits long, while mode fields of 5 and 6 are used for 16-bit and 8-bit immediate data, respectively. Figure 5-11 illustrates the storage of the instruction MOVW &0x12345678,% r2 in memory. This instruction causes the immediate data, 0x12345678, to be placed into register r2.

Notice on Figure 5-11 that the immediate data is stored in memory with lower order bytes stored at lower order addresses. This is true for all immediate data; for example, the 16bit immediate data 0xABCD would be stored as CDAB, with the byte containing CD stored at the immediately lower address than the byte containing AB.

The immediate mode also has a short storage form for positive immediate data between 0 and 63, and negative data between -1 and -16. In these two cases, the immediate data is stored directly within the descriptor byte.



INCREASING MEMORY ADDRESSES

Figure 5-11. A 32-bit Immediate Source Operand

#### 5.6 ABSOLUTE MODE

In this mode, the address of the desired operand is contained directly within the instruction. The dollar symbol is used to indicate this addressing mode to the assembler.

For example, the instruction MOVB 0x2E04, r0 moves the byte starting at location 0x2E04 into register r0. The general syntax, mode, and register fields for the absolute address mode are:

```
syntax: $expr (expr must yield to a byte, halfword, or word)
mmmm: 7
rrrr: 15
```

Thus, the instruction MOVB \$0x2E04,% r0 is stored in memory as shown on Figure 5-12.

As illustrated on Figure 5-12, the memory address is stored as a 32-bit address with lower-order bytes stored in lower order memory addresses.

#### 5.7 ABSOLUTE DEFERRED MODE

In the absolute deferred mode, the address contained within the instruction is used as a pointer to a word containing the address of the operand. As in all deferred modes, an asterisk is used to indicate deferred addressing to the assembler.

For example, the instruction MOVB \*\$0x2E04,% r0 uses the data contained within memory location 0x2E04 as the address of the source operand. The general syntax, mode, and register fields for this deferred mode is:

syntax: \*\$expr (expr must yield to a byte, halfword, or word) mmmm: 14 rrrr: 15

Thus, the instruction MOVB \*\$0x2E04,% r0 is stored in memory as illustrated on Figure 5-13.



INCREASING MEMORY ADDRESSES



INCREASING MEMORY ADDRESSES MOVB SOURCE DESTINATION 32 - BIT POINTER ADDRESS DESCRIPTOR DESCRIPTOR OPCODE 0x04 0 x 0 0 0x00 Е F 0 x 2 E 4 0 0 x 87 MODE MODE REG FIELD FIELD FIELD FIELD REGISTER MODE ABSOLUTE DEFERRED MODE



#### 5.8 EXPANDED OPERAND MODE

The expanded operand mode changes the type of an operand. For example, using this mode a signed byte located in a register could be converted to an unsigned halfword stored into memory.

The expanded operand mode does not affect the length of immediate operands, but does affect whether they are treated as signed or unsigned. The expanded operand mode does not affect the treatment of literals.

In assembly language, the syntax of this mode is

{type}operand

where *operand* is an operand having any address mode except an expanded operand mode. When the expanded operand mode is used, *type* overrides the operand's normal data type, except as noted above. The new type remains in effect for the operands that follow in the instruction unless another expanded operand mode overrides it. Table 5-3 lists the syntax for *type*.

The expanded operand mode requires two descriptor bytes as shown on Figure 5-14. The first byte identifies the expanded operand mode and the new type, while the second is the descriptor byte for the address mode. The type field contains the value of the new type (see Table 5-3). The second byte contains the mode field (mmmm) and the register field (rrrr) for the address mode. This byte is the descriptor byte for the new address mode. For example, the following instruction converts a signed byte into an unsigned halfword:

MOVB {sbyte}% r0,{uhalf}4(% r1)



Figure 5-14. Expanded Operand Mode Descriptor Bytes

The first operand's real mode is register, the second operand is byte displacement. The instruction reads bits 0 through 7 from register 0, extends the sign bit (7) through 32 bits, and writes an unsigned halfword. The bytes are stored in memory as illustrated on Figure 5-15.

The expanded operand mode is illegal with coprocessor instructions and CALL, SAVE, RESTORE, SWAP INTERLOCKED, PUSHW, PUSHAW, POPW, and JSB instructions and will generate an illegal operand fault.

| Table 5-3. Options for type in Expanded Operand Mode |               |    |  |  |  |
|------------------------------------------------------|---------------|----|--|--|--|
| Type Syntax Type Field<br>(See Note)                 |               |    |  |  |  |
| Signed byte                                          | sbyte         | E7 |  |  |  |
| Signed halfword                                      | half or shalf | E6 |  |  |  |
| Signed word                                          | word or sword | E4 |  |  |  |
| Unsigned byte                                        | byte or ubyte | E3 |  |  |  |
| Unsigned halfword                                    | uhalf         | E2 |  |  |  |
| Unsigned word                                        | uword         | EO |  |  |  |

Note: Type fields E1, E5, E8-E14 are reserved data types. Type field EF is an absolute deferred data type.



INCREASING MEMORY ADDRESS ST

Figure 5-15. Expanded Operand Mode Example

# 5.9 SUMMARY

In machine language, the first byte of the operand, the descriptor byte, defines the operand's addressing mode. This byte consists of a mode and register field, which together define an addressing mode (the expanded operand type mode uses two descriptor bytes). Bytes following the descriptor byte contain additional data required by the addressing mode. Table 5-4 provides a summary of the addressing modes and their syntax. The descriptions within the table use the following notation:

| Oxnnn | Hexadecimal number nnn, where n is a hexadecimal digit 0 to 9 or a to f (or A to F); may also be written $0Xnnn$                                                                                       |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| %ap   | Argument pointer (AP); contains the starting location on the stack of a list of arguments for a function                                                                                               |
| expr  | User-supplied expression that yields a byte, halfword, or word                                                                                                                                         |
| %fp   | Frame pointer (FP); contains the starting location on the stack of local variables for a function                                                                                                      |
| imm8  | Signed integer in the range $-128$ to $+127$ (i.e., $-2^7$ to $+2^7-1$ )                                                                                                                               |
| imm16 | Signed integer in the range $-32768$ to $+32767$ ; i.e., $-2^{15}$ to $(+2^{15}-1)$                                                                                                                    |
| imm32 | Signed integer in the range $-2^{31}$ to $(+2^{31}-1)$                                                                                                                                                 |
| lit   | Signed integer in the range $-16$ to $+63$                                                                                                                                                             |
| opnd  | An operand that uses a mode other than the expanded operand type                                                                                                                                       |
| %     | References a processor register; use the syntax shown in Table 5-4 for the desired register                                                                                                            |
| so    | Short offset; an integer in the range 0 to 14                                                                                                                                                          |
| type  | Data type: sbyte (for signed byte), byte or ubyte (for unsigned byte), half or shalf (for signed halfword), uhalf (for unsigned halfword), word or sword (for signed word), uword (for unsigned word). |

| Table 5-4. Addressing Modes |                  |               |                   |                |       |  |  |
|-----------------------------|------------------|---------------|-------------------|----------------|-------|--|--|
| Mode                        | Syntax           | Mode<br>Field | Register<br>Field | Total<br>Bytes | Notes |  |  |
|                             | Absolute         |               |                   |                |       |  |  |
| Absolute                    | \$expr           | 7             | 15                | 5              |       |  |  |
| Absolute deferred           | *\$expr          | 14            | 15                | 5              |       |  |  |
|                             | Displacement (fr | om a rej      | gister)           |                |       |  |  |
| Byte displacement           | expr(% rn)       | 12            | 0-10,12-15        | 2              | -     |  |  |
| Byte displacement           |                  |               |                   |                |       |  |  |
| deferred                    | *expr(% rn)      | 13            | 0-10,12-15        | 2              |       |  |  |
| Halfword displacement       | expr(% rn)       | 10            | 0-10,12-15        | 3              | -     |  |  |
| Halfword displacement       |                  |               |                   |                |       |  |  |
| deferred                    | *expr(% rn)      | 11            | 0-10,12-15        | 3              | -     |  |  |
| Word displacement           | expr(% rn)       | 8             | 0-10,12-15        | 5              |       |  |  |
| Word displacement           |                  |               |                   |                |       |  |  |
| deferred                    | *expr(% rn)      | 9             | 0-10,12-15        | 5              | _     |  |  |
| AP short offset             | so(%ap)          | 7             | 0-14              | 1              | 1     |  |  |
| FP short offset             | so(%fp)          | 6             | 0-14              | 1              | 1     |  |  |
|                             | Immed            | liate         |                   |                |       |  |  |
| Byte immediate              | &imm8            | 6             | 15                | 2              | 2,3   |  |  |
| Halfword immediate          | &imm16           | 5             | 15                | 3              | 2,3   |  |  |
| Word immediate              | &imm32           | 4             | 15                | 5              | 2,3   |  |  |
| Positive literal            | &lit             | 0-3           | 0-15              | 1              | 2,3   |  |  |
| Negative literal            | &lit             | 15            | 0-15              | 1              | 2,3   |  |  |
| Register                    |                  |               |                   |                |       |  |  |
| Register                    | % rn             | 4             | 0-14              | 1              | 1,3   |  |  |
| Register deferred           | (% rn)           | 5             | 0-10,12-14        | 1              | 1     |  |  |
|                             | Special Mode     |               |                   |                |       |  |  |
| Expanded operand            | {type}opnd       | 14            | 0-14              | 2-6            | 4     |  |  |

Notes:

- 1. Mode field has special meaning if register field is 15; see absolute or immediate mode.
- 2. Mode may not be used for a destination operand.
- 3. Mode may not be used if the instruction takes effective address of the operand.
- 4. *type* overrides instruction type; *type* determines the operand type, except that it does not determine the length for immediates or literals or whether literals are signed or unsigned. *opnd* determines actual address mode. For total bytes, add 1 to byte count for address mode determined by *opnd*.



# CHAPTER 6. INSTRUCTION SET

# CONTENTS

| 6.1 WE 32100 MICROPROCESSOR INSTRUCTION SET |                   |
|---------------------------------------------|-------------------|
| 6.1.1 Condition Flags                       |                   |
| 6.2 FUNCTIONAL GROUPS                       | ••••••••••••••••• |
| 6.2.1 Data Transfer Instructions            |                   |
| 6.2.2 Arithmetic Instructions               |                   |
| 6.2.3 Logical Instructions                  |                   |
| 6.2.4 Program Control Instructions          |                   |
| 6.2.5 Coprocessor Instructions              |                   |
| 6.2.6 Stack and Miscellaneous Instructions  |                   |

# 6. INSTRUCTION SET

The instruction set for the assembler used by the AT&T 3B2/3B5/3B15 Computers consists of the WE 32100 Microprocessor instruction set, the IS25 instructions, and the Math Acceleration Unit Instruction Set (MIS). The IS25 instruction set, discussed in more detail in Appendix B. IS25 Instruction Set, was designed to be machine independent and therefore it allows programs to be written for all 3B computers including earlier version 3B computers. IS25 instructions may be used in place of the WE 32100 Microprocessor instruction set for some applications. Since 3B2/3B5/3B15 Computers use the WE 32100 Microprocessor as the CPU, the discussion in this chapter is limited to the microprocessor instruction set. The remainder of this chapter will discuss the use of the microprocessor instructions and give a listing of the instructions by functional group. For a detailed listing of each instructions, which are used to provide floating point support, are discussed in 10. Floating Point Support.

# 6.1 WE 32100 MICROPROCESSOR INSTRUCTION SET

The WE 32100 Microprocessor has a powerful instruction set that includes the standard data transfer, arithmetic, and logical operations for microprocessors, plus some unique operating system operations. Its many program control instructions (branch, jump, return) provide flexibility for altering the sequence in which instructions are executed. Some of these instructions check the setting of the processor's condition flags before execution. For operation systems, the processor has instructions to establish an environment that permits other processes to take control of the processor. The special instructions dedicated to operating system use are discussed in 9. Operating System Interface.

The microprocessor instructions are mnemonic-based assembly language statements. A mnemonic defines the operation an instruction performs. For most arithmetic or logical operations, the mnemonic also defines one of the data types:

- byte 8-bit data
- halfword 16-bit data
- word 32-bit data

Some instructions perform operations on a *bit field*, a sequence of 1 to 32 bits contained in a word, or on a *block* (or *string*) of data locations. Data types are discussed in 4.1 Data Types.

Instructions may appear at any byte address. An instruction consists of a one- or two-byte opcode followed by zero or up to four operands. In assembly language, the mnemonic replaces the opcode and is followed by its operands. This is represented as:

mnemonic opnd1,opnd2,opnd3,opnd4

where the mnemonic is separated from the operands by a white space (tab or space) and commas are used to separate operands. The different addressing modes and formats of the operands are discussed in 5. Addressing Modes.

#### 6.1.1 Condition Flags

Bits 21 to 18 of the processor status word (PSW) contain four condition flags (N, Z, V, and C) that are affected by most instructions. The order is shown on Figure 6-1. The conditional program-control instructions check one or more of these flags before executing the branch, jump, or return. In general, these flags reflect the result of the most recent instruction that which affected them. Most instructions set the flags according to standard criteria. Before defining that criteria, the following terms are defined:

- Result refers to the internal result of the operation as if it were performed in an infinite-precision machine. The microprocessor operates on 32-bit data internally and uses a 33-bit space for the internal result. Bytes and halfwords read in are extended to 32 bits before the operation. The destination operand determines the *type* (i.e., signed or unsigned, and size: byte, halfword, or word) of this result.
- Output value refers to the data written to the destination location. The size of this data, 8-, 16-, or 32-bits, corresponds to the data type of the destination operand: byte, halfword, or word, respectively.

The following conditions cause the appropriate flag bit to be altered:

- N Negative (PSW bit 21) Logical instructions change N to the setting of the output value of the MSB: bit 31 for words, bit 15 for halfwords, and bit 7 for bytes. For all other instructions, N is set if the sign of the result is negative. If truncation occurs, the N flag may be set even though the sign bit of the output value is zero. Zero is considered positive.
- Z Zero (PSW bit 20) Logical instructions set Z if the output value is zero. For all other instructions Z is set if the result is equal to zero. If truncation occurs, the Z flag may not be set even though all bits of the output value are zero.
- V Overflow (PSW bit 19) For instructions with a signed destination, V is set if the sign bit of the output value is different from any truncated bit of the result. For instructions with an unsigned destination, V is set if any truncated bit is a one. The arithmetic left shift operation sets the V bit only if a truncation error occurs. Bit, compare, and test instructions always reset V.



Figure 6-1. Condition Flags

C Carry/Borrow (PSW bit 18) – Logical instructions clear this bit. For all other instructions, the type of the result determines the state of the C bit. C is set if a carry occurs into the 33rd bit for word operations, into the 17th bit for halfword operations, or into the 9th bit for byte operations. The C bit is set if a borrow occurs from these bits for subtract, negate, and decrement. For example, consider A minus B where A and B are unsigned. If  $A \ge B$  after both are extended to 32 bits, then C is cleared. Otherwise, the C flag is set.

Note: If a memory-write fault occurs, the flags are set as if the instruction was completed normally.

The instruction descriptions later in this chapter include the effect that each instruction has on the condition flags.

# 6.2 FUNCTIONAL GROUPS

The WE 32100 Microprocessor instruction set may be separated into six functional groups: data transfer instructions, arithmetic instructions, logical instructions, program control instructions, coprocessor instructions, and stack and miscellaneous instructions. This section contains a description of each group, along with an instruction listing of each group (Tables 6-1 to 6-6). Byte and cycle counts are included for the various addressing modes for each instruction. The conditions column in the instruction listing refers to the condition flag code assignment cases listed in Table 6-7.

#### **Instruction Timing**

The architecture of the WE 32100 CPU makes exact instruction timing calculations difficult due to the following effects:

- Addressing modes of operands
- On-chip instruction cache
- Instruction pipelining
- Instruction and data alignment
- Data dependencies

The entries in the cycle count column in Tables 9 through 15 contain the ranges, from practical best to worst case, derived from tests taking all of the above effects into consideration. It is recommended that actual benchmarks be run to more accurately measure performance. The following discussion describes the timing differences due to the above effects.

Addressing Modes of Operands. Since the instruction set is orthogonal to the addressing modes of its operands, tests were done on each applicable combination of the five basic addressing mode classes (register, absolute address, register deferred, immediate, and absolute deferred) for each instruction. Due to the nature of the addressing modes, register operations take the least time, while the absolute deferred operations take the most time to execute.

**On-Chip Instruction Cache.** Timing differences caused by this effect were determined by ensuring that the test instruction was in the cache prior to execution (best case) and by first flushing the cache and then executing the test instruction (worst case). By flushing the cache a prefetch had to be performed to load the cache with the instruction. Performance improvements averaged 20-60% for ALU instructions, depending on the length of the instruction, by eliminating instruction prefetches.

**Instruction Pipelining**. Tests to determine the timing differences due to pipelining were selected by inserting a test instruction that had potential for overlapping with two surrounding instructions and by inserting a test instruction between two branch taken instructions (using the branch instructions eliminate pipeline overlap). These tests showed on the average that pipelining saved between 2 to 6 cycles for instruction execution times.

**Instruction and Data Alignment**. In test runs taking this effect into account, performance increases of an average of 2 to 6 cycles were encountered for optimal alignment. Optimal alignment was obtained by placing as many of the test instruction's opcode and associated operands as possible on word boundaries. Worst case alignment minimizes alignment of the opcode and operands.

**Data Dependencies.** This effect was found only in four instructions: MULW2, DIVW2, STRCPY, and STREND. In the test involving the MULW2 and DIVW2 instructions timing is improved if at least one operand is zero. For the string instructions, the length of the string has a large impact on the instruction execution time. Since string lengths are not limited, test runs were done on strings of one byte (best case) and four bytes (worst case) to determine best and worst case timings.

# 6.2.1 Data Transfer Instructions

These instructions (listed in Table 6-1) transfer data to and from registers and memory. Most of them have three types (indicated by the last character of the mnemonic): byte (B), halfword (H), and word (W). A mnemonic's type determines the type of each operand in the instruction, unless the expanded-operand type mode changes an operand's type. The type of the destination operand (dst) determines how the condition flags are set (see 6.1.1 Condition Flags).

| Table 6-1. Data Transfer Instruction Group |          |        |       |          |             |  |
|--------------------------------------------|----------|--------|-------|----------|-------------|--|
| Instruction                                | Mnemonic | Opcode | Bytes | Cycles   | Conditions* |  |
| Move:                                      |          |        |       |          |             |  |
| Move byte                                  | MOVB     | 0x87   | 3-11  | 2-31     |             |  |
| Move halfword                              | MOVH     | 0x86   | 3-11  | 2-31     |             |  |
| Move word                                  | MOVW     | 0x84   | 3-11  | 1-27     |             |  |
| Move address (word)                        | MOVAW    | 0x04   | 3-11  | 2-22     | Case 1      |  |
| Move complemented byte                     | MCOMB    | 0x8B   | 3-11  | 2-31     |             |  |
| Move complemented halfword                 | мсомн    | 0x8A   | 3-11  | 2-31     |             |  |
| Move complemented word                     | MCOMW    | 0x88   | 3-11  | 1-27     |             |  |
| Move negated byte                          | MNEGB    | 0x8F   | 3-11  | 2-31     |             |  |
| Move negated halfword                      | MNEGH    | 0x8E   | 3-11  | 2-31     | Case 2      |  |
| Move negated word                          | MNEGW    | 0x8C   | 3-11  | 1-27     |             |  |
| Move version number                        | MVERNO   | 0x3009 | 2     | See Note | Unchanged   |  |
| Swap (Interlocked):                        |          |        |       |          |             |  |
| Swap byte interlocked                      | SWAPBI   | 0x1F   | 2-6   | 22-33    |             |  |
| Swap halfword interlocked                  | SWAPHI   | Ox1E   | 2-6   | 22-33    | Case 1      |  |
| Swap word interlocked                      | SWAPWI   | Ox1C   | 2-6   | 18-28    |             |  |
| Block Operations:                          |          |        |       |          |             |  |
| Move block of words                        | MOVBLW   | 0x3019 | 2     | See Note | Unchanged   |  |
| Field Operations:                          |          |        |       |          |             |  |
| Extract field byte                         | EXTFB    | 0xCF   | 5-21  | 7-55     |             |  |
| Extract field halfword                     | EXTFH    | 0xCE   | 5-21  | 7-55     |             |  |
| Extract field word                         | EXTFW    | 0xCC   | 5-21  | 4-54     | Case 1      |  |
| Insert field byte                          | INSFB    | 0xCB   | 5-21  | 18-72    |             |  |
| Insert field halfword                      | INSFH    | 0xCA   | 5-21  | 18-72    |             |  |
| Insert field word                          | INSFW    | 0xC8   | 5-21  | 14-71    |             |  |
| String Operations:                         |          |        |       |          |             |  |
| String copy                                | STRCPY   | 0x3035 | 2     | 83-182** | Unchanged   |  |
| String end                                 | STREND   | 0x301F | 2     | 54-120** | Chichangeu  |  |

\*Refer to Table 6-7 for condition flag code assignments.

\*\*Cycle count per word access.

Note: Information Unavailable

# 6.2.2 Arithmetic Instructions

Arithmetic instructions (listed in Table 6-2) perform arithmetic operations on data in registers and memory. Most of these instructions have three types (specified by the last alphabetic character of the mnemonic): byte (B), halfword (H), and word (W). This type specification applies to each operand in the instruction, unless the expanded-operand type mode changes an operand's type. The type of the destination operand (dst) determines how the condition flags are set (see 6.1.1 Condition Flags).

Many arithmetic operations are available as two- or three-address instructions. A twoaddress instruction has a source operand (src) and a destination operand. Three-address instructions have two source operands (src1, src2) and a destination operand. A few instructions also have a count operand (count).

If the result of an arithmetic operation is too large to be represented in 32 bits, the highorder bits are truncated and the processor issues an integer-overflow exception.

| Table 6-2.         Arithmetic Instruction Group |          |             |       |        |             |  |
|-------------------------------------------------|----------|-------------|-------|--------|-------------|--|
| Instruction                                     | Mnemonic | Opcode      | Bytes | Cycles | Conditions* |  |
| Add:                                            |          |             |       |        |             |  |
| Add byte                                        | ADDB2    | 0x9F        | 3-11  | 4-33   |             |  |
| Add halfword                                    | ADDH2    | 0x9E        | 3-11  | 4-33   | • .         |  |
| Add word                                        | ADDW2    | 0x9C        | 3-11  | 2-31   |             |  |
| Add byte, 3-address                             | ADDB3    | <b>0xDF</b> | 4-16  | 4-44   |             |  |
| Add halfword, 3-address                         | ADDH3    | 0xDE        | 4-16  | 4-44   |             |  |
| Add word, 3-address                             | ADDW3    | 0xDC        | 4-16  | 4-43   |             |  |
| Subtract:                                       |          |             |       |        |             |  |
| Subtract byte                                   | SUBB2    | <b>OxBF</b> | 3-11  | 4-33   |             |  |
| Subtract halfword                               | SUBH2    | <b>0xBE</b> | 3-11  | 4-33   | Case 2      |  |
| Subtract word                                   | SUBW2    | 0xBC        | 3-11  | 2-31   |             |  |
| Subtract byte, 3-address                        | SUBB3    | <b>0xFF</b> | 4-16  | 4-44   |             |  |
| Subtract halfword, 3-address                    | SUBH3    | 0xFE        | 4-16  | 4-43   |             |  |
| Subtract word, 3-address                        | SUBW3    | 0xFC        | 4-16  | 4-43   |             |  |
| Increment:                                      |          |             |       |        |             |  |
| Increment byte                                  | INCB     | 0x93        | 2-6   | 2-24   |             |  |
| Increment halfword                              | INCH     | 0x92        | 2-6   | 2-24   |             |  |
| Increment word                                  | INCW     | 0x90        | 2-6   | 1-22   |             |  |
| Decrement:                                      |          |             |       |        |             |  |
| Decrement byte                                  | DECB     | 0x97        | 2-6   | 2-24   |             |  |
| Decrement halfword                              | DECH     | 0x96        | 2-6   | 2-24   |             |  |
| Decrement word                                  | DECW     | 0x94        | 2-6   | 1-22   |             |  |

\*Refer to Table 6-7 for condition flag code assignments.

· .

#### INSTRUCTION SET Logical Instructions

| Table 6-2.         Arithmetic Instruction Group (Continued) |          |             |        |          |             |  |
|-------------------------------------------------------------|----------|-------------|--------|----------|-------------|--|
| Instruction                                                 | Mnemonic | Opcode      | Bytes  | Cycles   | Conditions* |  |
| Multiply:                                                   |          |             |        |          |             |  |
| Multiply byte                                               | MULB2    | 0xAB        | 3-11   | 20-91    | )           |  |
| Multiply halfword                                           | MULH2    | 0xAA        | 3-11   | 20-130   | Case 3      |  |
| Multiply word                                               | MULW2    | 0xA8        | 3-11   | 18-210   |             |  |
| Multiply byte, 3-address                                    | MULB3    | 0xEB4-16    | 22-204 |          |             |  |
| Multiply halfword, 3-address                                | MULH3    | 0xEA        | 4-16   | 22 - 200 | Case 4      |  |
| Multiply word, 3-address                                    | MULW3    | 0xE8        | 4-16   | 20-205   |             |  |
| Divide:                                                     |          |             |        |          |             |  |
| Divide byte                                                 | DIVB2    | <b>0xAF</b> | 3-11   | 21-154   |             |  |
| Divide halfword                                             | DIVH2    | 0xAE        | 3-11   | 21-194   | Case 3      |  |
| Divide word                                                 | DIVW2    | 0xAC        | 3-11   | 19-275   |             |  |
| Divide byte, 3-address                                      | DIVB3    | <b>0xEF</b> | 4-16   | 23-270   |             |  |
| Divide halfword, 3-address                                  | DIVH3    | <b>OxEE</b> | 4-16   | 23-263   | Case 4      |  |
| Divide word, 3-address                                      | DIVW3    | 0xEC        | 4-16   | 21 - 275 |             |  |
| Modulo:                                                     |          |             |        |          |             |  |
| Modulo byte                                                 | MODB2    | 0xA7        | 3-11   | 21-154   |             |  |
| Modulo halfword                                             | MODH2    | 0xA6        | 3-11   | 21-194   | Case 3      |  |
| Modulo word                                                 | MODW2    | 0xA4        | 3-11   | 19-275   |             |  |
| Modulo byte, 3-address                                      | MODB3    | 0xE7        | 4-16   | 23-270   |             |  |
| Modulo halfword, 3-address                                  | MODH3    | 0xE6        | 4-16   | 23-263   | Case 4      |  |
| Modulo word, 3-address                                      | MODW3    | 0xE4        | 21-275 |          |             |  |
| Arithmetic Shift:                                           |          |             |        |          |             |  |
| Arithmetic left shift word                                  | ALSW3    | 0xC0        | 4-16   | 5-43     | Case 5      |  |
| Arithmetic right shift byte                                 | ARSB3    | 0xC7        | 4-16   | 5-44     |             |  |
| Arithmetic right shift halfword                             | ARSH3    | 0xC6        | 4-16   | 5-44     | Case 3      |  |
| Arithmetic right shift word                                 | ARSW3    | 0xC4        | 4-16   | 5-43     |             |  |

\*Refer to Table 6-7 for condition flag code assignments.

#### 6.2.3 Logical Instructions

Logical instructions (listed in Table 6-3) perform logical operations on data in registers and memory. Most of these instructions have three types (specified by the last character of the mnemonic): byte (B), halfword (H), and word (W). A mnemonic's type determines the type of each operand in the instruction, unless the expanded-operand type mode changes an operand's type. The type of the destination operand (dst) determines how the condition flags are set (see 6.1.1 Condition Flags).

Many logical operations are available as two- or three-address instructions. A two-address instruction has a source operand (src) and a destination operand (dst). Three-address instructions have two source operands (src1, src2) and a destination operand. A few instructions have a read-only count operand (count).

| Table 6-3. Logical Instruction Group |          |        |       |        |             |  |
|--------------------------------------|----------|--------|-------|--------|-------------|--|
| Instruction                          | Mnemonic | Opcode | Bytes | Cycles | Conditions* |  |
| AND:                                 |          |        |       |        |             |  |
| AND byte                             | ANDB2    | 0xBB   | 3-11  | 4-33   |             |  |
| AND halfword                         | ANDH2    | 0xBA   | 3-11  | 4-33   |             |  |
| AND word                             | ANDW2    | 0xB8   | 3-11  | 2-31   |             |  |
| AND byte, 3-address                  | ANDB3    | 0xFB   | 4-16  | 4-44   |             |  |
| AND halfword, 3-address              | ANDH3    | 0xFA   | 4-16  | 4-44   |             |  |
| AND word, 3-address                  | ANDW3    | 0xF8   | 4-16  | 4-43   |             |  |
| Exclusive OR (XOR):                  |          |        |       |        |             |  |
| Exclusive OR byte                    | XORB2    | 0xB7   | 3-11  | 4-33   |             |  |
| Exclusive OR halfword                | XORH2    | 0xB6   | 3-11  | 4-33   | Case 1      |  |
| Exclusive OR word                    | XORW2    | 0xB4   | 3-11  | 2-31   |             |  |
| Exclusive OR byte, 3-address         | XORB3    | 0xF7   | 4-16  | 4-44   |             |  |
| Exclusive OR halfword, 3-address     | XORH3    | 0xF6   | 4-16  | 4-44   |             |  |
| Exclusive OR word, 3-address         | XORW3    | 0xF4   | 4-16  | 4-43   |             |  |
| OR:                                  |          |        |       |        |             |  |
| OR byte                              | ORB2     | 0xB3   | 3-11  | 4-33   |             |  |
| OR halfword                          | ORH2     | 0xB2   | 3-11  | 4-33   |             |  |
| OR word                              | ORW2     | 0xB0   | 3-11  | 2-31   |             |  |
| OR byte, 3-address                   | ORB3     | 0xF3   | 4-16  | 4-44   |             |  |
| OR halfword, 3-address               | ORH2     | 0xF2   | 4-16  | 4-44   |             |  |
| OR word, 3-address                   | ORW3     | 0xF0   | 4-16  | 4-43   |             |  |
| Compare or Test:                     |          |        |       |        |             |  |
| Compare byte                         | СМРВ     | 0x3F   | 3-11  | 4-33   |             |  |
| Compare halfword                     | СМРН     | 0x3E   | 3-11  | 4-33   | Case 2      |  |
| Compare word                         | CMPW     | 0x3C   | 3-11  | 2-31   |             |  |
| Test byte                            | TSTB     | 0x2B   | 2-6   | 2-24   |             |  |
| Test halfword                        | TSTH     | 0x2A   | 2-6   | 2-24   | Case 6      |  |
| Test word                            | TSTW     | 0x28   | 2-6   | 1-18   |             |  |
| Bit test byte                        | BITB     | 0x3B   | 3-11  | 4-31   |             |  |
| Bit test halfword                    | BITH     | 0x3A   | 3-11  | 4-31   | Case 1      |  |
| Bit test word                        | BITW     | 0x38   | 3-11  | 2-30   |             |  |
| Clear:                               |          |        |       |        |             |  |
| Clear byte                           | CLRB     | 0x83   | 2-6   | .2-21  |             |  |
| Clear halfword                       | CLRH     | 0x82   | 2-6   | 2-21   | Case 2      |  |
| Clear word                           | CLRW     | 0x80   | 2-6   | 1-19   |             |  |
| Rotate or Logical Shift:             |          |        |       |        |             |  |
| Rotate word                          | ROTW     | 0xD8   | 4-16  | 5-43   |             |  |
| Logical left shift byte              | LLSB3    | 0xD3   | 4-16  | 5-44   |             |  |
| Logical left shift halfword          | LLSH3    | 0xD2   | 4-16  | 5-44   | Case 1      |  |
| Logical left shift word              | LLSW3    | 0xD0   | 4-16  | 5-43   |             |  |
| Logical right shift word             | LRSW3    | 0xD4   | 4-16  | 5-43   |             |  |

\*Refer to Table 6-7 for condition flag code assignments.

# 6.2.4 Program Control Instructions

Program control instructions (listed in Table 6-4) change the program sequence, but generally do not alter the condition flags.

Branch instructions have two types specified by the last character of the mnemonic: byte displacement (B) and halfword displacement (H). A mnemonic's type determines if an 8or a 16-bit displacement is embedded in the instruction. This displacement (disp8, disp16) is read, its sign is extended through 32 bits, and the result is added to the program counter (PC) to compute the target address. Jump instructions have a read-only, 32-bit destination (dst) operand that replaces the contents of the PC.

Jump instructions are always unconditional, but both conditional and unconditional branch and return instructions are provided. Unconditional transfers change the contents of the PC to the value specified. Conditional transfers first examine the status of the processor's condition flags to determine if the transfer should be executed.

Subroutine and procedure-call (function) transfer instructions save or restore registers so execution can transfer to the subroutine or function and then return to the original program sequence.

Subroutine Transfer. A subroutine transfer is different from a normal transfer. Before transferring to a subroutine, it saves the address of the next instruction.

Call and return instructions for subroutines always implicitly affect the stack pointer (SP). For subroutines, call saves the address of the next instruction on the stack at the location identified by the SP, increment the SP by 4, and then alter the PC. Return from subroutine decrements the SP by 4, retrieves the saved address from the stack, and writes it to the PC.

**Procedure Transfer.** For procedure transfers it is necessary to save other registers. These instructions establish the environment for a function in a high-level language. Call and save instructions automatically save the calling function's pointers, set up pointers to the new function's environment, call the function, and save registers for local variables. Restore and return instructions remove that environment and return to the calling function.

A stack frame provides reserved space, including a register-save area, for each function. The register-save area stores the calling function's FP, AP, return PC, and registers 3 through 8 ( $r_3 - r_8$ ), if requested. Saving r3 through r8 gives the new function space for up to six register variables. The SP is not saved because its value is always implicit.

All function calls have a fixed-size register-save area, even though some of it may not be used. Save and restore control the number of the six user registers r3 through r8 that will be saved and restored. A return from a function retrieves the saved pointers and registers to restore the original function's environment.

# INSTRUCTION SET Program Control Instructions

| Table 6-4. Program Control Instruction Group |          |                                        |     |            |                                       |  |  |
|----------------------------------------------|----------|----------------------------------------|-----|------------|---------------------------------------|--|--|
| Instruction                                  | Mnemonic | Mnemonic Opcode Bytes Cycles Condition |     |            |                                       |  |  |
| Unconditional Transfer:                      |          |                                        |     |            |                                       |  |  |
| Branch with byte (8-bit)                     | BRB      | 0x7B                                   | 2   | 5-16       |                                       |  |  |
| displacement                                 |          |                                        |     |            |                                       |  |  |
| Branch with halfword (16-bit)                | BRH      | 0x7A                                   | 3   | 5-14       |                                       |  |  |
| displacement                                 |          |                                        |     |            |                                       |  |  |
| Jump                                         | JMP      | 0x24                                   | 2-6 | 7-17       |                                       |  |  |
| Conditional Transfers:                       |          |                                        |     |            |                                       |  |  |
| Branch on carry clear byte                   | BCCB     | 0x53*                                  | 2   | See Note 1 |                                       |  |  |
| Branch on carry clear halfword               | BCCH     | 0x52*                                  | 3   | See Note 2 |                                       |  |  |
| Branch on carry set byte                     | BCSB     | 0x5B*                                  | 2   | See Note 1 |                                       |  |  |
| Branch on carry set halfword                 | BCSH     | 0x5A*                                  | 3   | See Note 2 |                                       |  |  |
| Branch on overflow clear,                    | BVCB     | 0x63                                   | 2   | Note 1     |                                       |  |  |
| byte displacement                            |          |                                        |     |            | -                                     |  |  |
| Branch on overflow clear,                    | BVCH     | 0x62                                   | 3   | See Note 2 | · · · · · · · · · · · · · · · · · · · |  |  |
| halfword displacement                        |          |                                        |     |            |                                       |  |  |
| Branch on overflow set,                      | BVSB     | 0x6B                                   | 2   | See Note 1 | Unchanged                             |  |  |
| byte displacement                            |          |                                        |     |            |                                       |  |  |
| Branch on overflow set,                      | BVSH     | 0x6A                                   | 3   | See Note 2 |                                       |  |  |
| halfword displacement                        |          |                                        |     |            |                                       |  |  |
| Branch on equal byte                         | BEB      | 0x6F                                   | 2   | See Note 1 |                                       |  |  |
| (duplicate)                                  |          |                                        |     |            |                                       |  |  |
| Branch on equal byte                         | BEB      | 0x7F                                   | 2   | See Note 1 |                                       |  |  |
| Branch on equal halfword                     | BEH      | 0x6E                                   | 3   | See Note 2 |                                       |  |  |
| (duplicate)                                  |          |                                        |     |            |                                       |  |  |
| Branch on equal halfword                     | BEH      | 0x7E                                   | 3   | See Note 2 |                                       |  |  |
| Branch on not equal byte                     | BNEB     | 0x67                                   | 2   | See Note 1 |                                       |  |  |
| (duplicate)                                  |          |                                        |     |            |                                       |  |  |
| Branch on not equal byte                     | BNEB     | 0x77                                   | 2   | See Note 1 |                                       |  |  |
| Branch on not equal halfword                 | BNEH     | 0x66                                   | 3   | See Note 2 |                                       |  |  |
| (duplicate)                                  |          |                                        |     |            |                                       |  |  |
| Branch on not equal halfword                 | BNEH     | 0x76                                   | 3   | See Note 2 |                                       |  |  |
| Branch on less than byte                     | BLB      | 0x4B                                   | 2   | See Note 1 |                                       |  |  |
| (signed)                                     |          |                                        |     |            |                                       |  |  |
| Branch on less than halfword                 | BLH      | 0x4A                                   | 3   | See Note 2 |                                       |  |  |
| (signed)                                     |          |                                        |     |            |                                       |  |  |

\*Refer to Table 6-7 for condition flag code assignments.

\*\*Indicates that opcode matches another instruction but operation is the same. \*\*\*Dependent on number of registers saved/restored.

1. 5-10 cycles during a branch not taken; 7-14 cycles during a branch taken.

2. 5-10 cycles during a branch not taken; 7-12 cycles during a branch taken.

3. 4-5 cycles during a return not taken; 13-14 cycles during a return taken.

| Table 6-4. Program Control Instruction Group (Continued) |                                 |        |     |            |            |  |
|----------------------------------------------------------|---------------------------------|--------|-----|------------|------------|--|
| Instruction                                              | Mnemonic Opcode Bytes Cycles Co |        |     |            | Conditions |  |
| Branch on less than byte                                 | BLUB                            | 0x5B** | 2   | See Note 1 |            |  |
| (unsigned)                                               |                                 |        |     |            |            |  |
| Branch on less than halfword                             | BLUH                            | 0x5A** | 3   | See Note 2 |            |  |
| (unsigned)                                               |                                 |        |     |            |            |  |
| Unconditional Transfer: (Continued)                      |                                 |        |     | ~          |            |  |
| Branch on less than or equal                             | BLEB                            | 0x4F   | 2   | See Note 1 |            |  |
| byte (signed)                                            | DIFU                            | 0-45   |     | C. Note 2  |            |  |
| Branch on less than or equal                             | BLEH                            | 0x4E   | 3   | See Note 2 |            |  |
| halfword (signed)                                        | DIFUD                           |        |     |            |            |  |
| Branch on less than or equal                             | BLEOB                           | UXSF   | 2   | See Note I |            |  |
| Branch on less than or equal                             | DIEIIU                          | 0.55   | 2   | See Note 2 |            |  |
| balfword (unsigned)                                      | bLEON                           | UXJE   | 5   | See Note 2 |            |  |
| Branch on greater than byte                              | BCB                             | 0x47   | 2   | See Note 1 |            |  |
| (signed)                                                 | DOD                             | 0.47   | 2   | See Note 1 |            |  |
| Branch on greater than                                   | BGH                             | 0x46   | 3   | See Note 2 | Unchanged  |  |
| halfword (signed)                                        |                                 | 0/4/10 |     |            | Chennengen |  |
| Branch on greater than byte                              | BGUB                            | 0x57   | 2   | See Note 1 |            |  |
| (unsigned)                                               | 2002                            |        | -   |            |            |  |
| Branch on greater than                                   | BGUH                            | 0x56   | 3   | See Note 2 |            |  |
| halfword (unsigned)                                      |                                 |        |     |            |            |  |
| Branch on greater than or                                | BGEB                            | 0x43   | 2   | See Note 1 |            |  |
| equal byte (signed)                                      |                                 |        |     |            |            |  |
| Branch on greater than or                                | BGEH                            | 0x42   | 3   | See Note 2 |            |  |
| equal halfword (signed)                                  |                                 |        |     |            |            |  |
| Branch on greater than or                                | BGEUB                           | 0x53** | 2   | See Note 1 |            |  |
| equal byte (unsigned)                                    |                                 |        |     |            |            |  |
| Branch on greater than or                                | BGEUH                           | 0x52** | 3   | See Note 2 |            |  |
| equal halfword (unsigned)                                |                                 |        |     |            |            |  |
| Return on carry clear                                    | RCC                             | 0x50** | 1   | See Note 3 |            |  |
| Return on carry set                                      | RCS                             | 0x58** | 1   | See Note 3 |            |  |
| Return on overflow clear                                 | RVC                             | 0x60   | 1   | See Note 3 |            |  |
| Return on overflow set                                   | RVS                             | 0x68   | 1   | See Note 3 |            |  |
| Return on equal (unsigned)                               | REQLU                           | 0x6C** | 1 . | See Note 3 |            |  |
| Return on equal                                          | REQL                            | 0x7C** | 1   | See Note 3 |            |  |

\*Refer to Table 6-7 for condition flag code assignments.

\*\*Indicates that opcode matches another instruction but operation is the same.

\*\*\*Dependent on number of registers saved/restored.

1. 5-10 cycles during a branch not taken; 7-14 cycles during a branch taken.

2. 5-10 cycles during a branch not taken; 7-12 cycles during a branch taken.

3. 4-5 cycles during a return not taken; 13-14 cycles during a return taken.

# INSTRUCTION SET Program Control Instructions

| Table 6-4. Program Control Instruction Group (Continued) |          |        |       |            |            |  |
|----------------------------------------------------------|----------|--------|-------|------------|------------|--|
| Instruction                                              | Mnemonic | Opcode | Bytes | Cycles     | Conditions |  |
| Return on not equal<br>(unsigned)                        | RNEQU    | 0x64** | 1     | See Note 3 |            |  |
| Return on not equal                                      | RNEQ     | 0x74** | 1     | See Note 3 |            |  |
| Return on less than (signed)                             | RLSS     | 0x48   | 1     | See Note 3 |            |  |
| Return on less than<br>(unsigned)                        | RLSSU    | 0x58** | 1     | See Note 3 |            |  |
| Return on less than or equal (signed)                    | RLEQ     | 0x4C   | 1     | See Note 3 | •          |  |
| Return on less than or equal (unsigned)                  | RLEQU    | 0x5C   | 1     | See Note 3 | Unchanged  |  |
| Return on greater than<br>(signed)                       | RGTR     | 0x44   | 1     | See Note 3 |            |  |
| Return on greater than<br>(unsigned)                     | RGTRU    | 0x54   | 1     | See Note 3 |            |  |
| Return on greater than or equal (signed)                 | RGEQ     | 0x40   | 1     | See Note 3 |            |  |
| Return on greater than or equal (unsigned)               | RGEQU    | 0x50** | 1     | See Note 3 |            |  |
| Subroutine Transfer:                                     |          |        |       |            |            |  |
| Branch to subroutine,<br>byte displacement               | BSBB     | 0x37   | 2     | See Note 2 |            |  |
| Branch to subroutine,<br>halfword displacement           | BSBH     | 0x36   | 3     | See Note 2 |            |  |
| Jump to subroutine                                       | JSB      | 0x34   | 2-6   | 7-17       |            |  |
| Return from subroutine                                   | RSB      | 0x78   | 1     | 13-14      |            |  |
| Procedure Transfer:                                      |          |        |       |            |            |  |
| Save registers                                           | SAVE     | 0x10   | 2     | 11-36***   |            |  |
| Restore registers                                        | RESTORE  | Ox18   | 2     | 12-38***   |            |  |
| Call procedure                                           | CALL     | 0x2C   | 7     | 25-36      |            |  |
| Return from procedure                                    | RET      | 0x08   | 1     | 21-23      |            |  |

\*Refer to Table 6-7 for condition flag code assignments.

\*\*Indicates that opcode matches another instruction but operation is the same. \*\*\*Dependent on number of registers saved/restored.

- 1. 5-10 cycles during a branch not taken; 7-14 cycles during a branch taken.
- 2. 5-10 cycles during a branch not taken; 7-12 cycles during a branch taken.

3. 4-5 cycles during a return not taken; 13-14 cycles during a return taken.
Procedure-call instructions explicitly manipulate four registers:

- 1. PC The call instruction saves the old PC as the return address (RA) and sets PC to the first executable instruction of the function being called. The return instruction restores PC to the RA (the next executable instruction of the calling function).
- 2. SP These instructions adjust SP automatically to point to the top of the stack whenever they store or retrieve items.
- 3. FP The save instruction sets FP to the address just above the saved registers. The FP accesses a region on the stack that stores temporary (or automatic) variables for the function.
- 4. AP The call instruction adjusts AP to the beginning of a list of arguments for the function.

On a function call, the calling function contains a call instruction; the save instruction should be the first statement of the called function. For a return, a restore and a return appear in the function being exited.

Figure 6-2 shows the stack after the CALL-SAVE sequence:

|        | PUSHW argl              | /*push three arguments*/ |
|--------|-------------------------|--------------------------|
|        | PUSHW arg2              |                          |
|        | PUSHW arg3              |                          |
|        | CALL -(3*4) (%sp),func1 | /*call function*/        |
|        | •                       |                          |
|        |                         | /*other instructions*/   |
|        | •                       |                          |
| func1: | SAVE %r3                | /*save r3 through r8*/   |

First, three arguments are pushed onto the stack; each push increments SP. Then CALL automatically saves the old pointers. It uses its first operand to set AP to the beginning of the three arguments and its second operand to call the function. Next, SAVE, the first statement in the function, is executed, automatically saving registers r3 through r8 by pushing them on the stack. It also adjusts SP and FP for each push.

To return to the original sequence, the function func1 contains the following instructions:

| func1: | SAVE %r3    | /*save r3 through r8*/                                   |  |  |
|--------|-------------|----------------------------------------------------------|--|--|
|        | •           | /*other instructions*/                                   |  |  |
|        | RESTORE %r3 | /*restore r3 through r8*/<br>/*return to main function*/ |  |  |



Figure 6-2. Stack After CALL-SAVE Sequence

The restore instruction retrieves registers r8 through r3 from the stack. It must have the same operand as the original SAVE; otherwise, the return (RET) cannot restore the correct AP and PC. Both instructions decrement SP as they pop the register contents from the stack.

#### 6.2.5 Coprocessor Instructions

These instructions which at present can only be used with the 3B2 Model 310 and 400 and the 3B15 Computers which contain the Math Acceleration Unit (MAU) (listed in Table 6-5), implement the interface with coprocessors. Most programmers will find it convenient to access the MAU using the MIS instruction set. All coprocessor instructions have an 8-bit opcode followed by one word. This word is transmitted on the data bus and interpreted by the coprocessor. The word is not used by the CPU. If no coprocessor responds to the transmitted word, an external memory fault occurs.

After the word following the opcode is transmitted, the source operands, if any, are fetched from memory. The CPU then waits until the "coprocessor done" signal is asserted, after which the CPU attempts to read a word. If this access is faulted, an external memory fault occurs. If this access is not faulted, bits 18 through 21 of the word are copied into bits 18 through 21 (condition flags) of the PSW. The resulting operand, if any, is then written to memory.

Coprocessor instructions can have from zero to two operands. The operands may be of three data types (specified by the last character of the mnemonic): single-word (S), double-word (D), and triple-word (T). All operands must start on an address evenly divisible by four (a word boundary).

#### 6.2.6 Stack and Miscellaneous Instructions

The stack instructions (listed in Table 6-6) are used to manipulate the stack. The push and pop instructions always process a word and alter the SP. They have a source operand src or a destination operand dst.

Miscellaneous instructions include those that alter the machine state or have an effect on the cache memory. The breakpoint instruction causes a breakpoint-trap exception. Control transfers to the operating system for the appropriate exception handler. The NOP instructions come in three lengths: 1, 2, or 3 bytes. If an instruction, other than a conditional transfer, reads the PSW, the assembler **as** inserts a NOP before that instruction. This allows time for the PSW codes to settle before the new instruction tries to access them. Cache flush makes the instruction cache invalid.

| Table 6-5. Coprocessor Instructions*   |          |        |      |        |              |
|----------------------------------------|----------|--------|------|--------|--------------|
| Instruction                            | Mnemonic | Opcode | Byte | Cycles | Conditions** |
| Coprocessor operation                  | SPOP     | 0x32   | 5    | N.A.   |              |
| Coprocessor operation read single      | SPOPRS   | 0x22   | 6-10 | N.A.   |              |
| Coprocessor operation double           | SPOPRD   | 0x02   | 6-10 | N.A.   |              |
| Coprocessor operation triple           | SPOPRT   | 0x06   | 6-10 | N.A.   |              |
| Coprocessor operation single 2-address | SPOPS2   | 0x23   | 7-15 | N.A.   | Case 10      |
| Coprocessor operation double 2-address | SPOPD2   | 0x03   | 7-15 | N.A.   | Case to      |
| Coprocessor operation triple 2-address | SPOPT2   | 0x07   | 7-15 | N.A.   |              |
| Coprocessor operation write single     | SPOPWS   | 0x33   | 6-10 | N.A.   |              |
| Coprocessor operation write double     | SPOPWD   | 0x13   | 6-10 | N.A.   |              |
| Coprocessor operation write triple     | SPOPWT   | 0x17   | 6-10 | N.A.   |              |

\*Can only be used with 3B2 (Model 310 and 400) and 3B15 Computers.

\*\*Refer to Table 6-7 for condition flag code assignments.

N.A. - Not available at time of production.

#### INSTRUCTION SET Stack and Miscellaneous Instructions

| Table 6-6.           | -6. Stack and Miscellaneous Instruction Groups |        |       |          | ips            |
|----------------------|------------------------------------------------|--------|-------|----------|----------------|
| Instruction          | Mnemonic                                       | Opcode | Bytes | Cycles   | Conditions*    |
| Stack Operations:    |                                                |        |       |          |                |
| Push address word    | PUSHAW                                         | 0xE0   | 2-6   | 9-20     |                |
| Push word            | PUSHW                                          | 0xA0   | 2-6   | 8-23     | Case 1         |
| Pop word             | POPW                                           | 0x20   | 2-6   | 9-23     |                |
| Miscellaneous:       |                                                |        |       |          |                |
| No operation, 1 byte | NOP                                            | 0x70   | 1     | 4-11     |                |
| No operation, 2 byte | NOP2                                           | 0x73   | 2     | 4-10     |                |
| No operation, 3 byte | NOP3                                           | 0x72   | 3     | 4-10     | <b>T</b> T 1 1 |
| Breakpoint trap      | BPT                                            | 0x2E   | 1     | See Note | Unchanged      |
| Cache flush          | CFLUSH                                         | 0x27   | 1     | See Note |                |
| Extended opcode      | EXTOP                                          | 0x14   | 1-2   | See Note |                |

\*Refer to Table 6-7 for condition flag code assignments. Note: Information Unavailable

|      | Table 6-7. Condition Flag Code Assignments |                   |                         |                          |                                                                                                                                                                                       |
|------|--------------------------------------------|-------------------|-------------------------|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | Condition Flags                            |                   |                         |                          |                                                                                                                                                                                       |
| Case | N(Negative)                                | Z(Zero)           | C(Carry)                | V(Overflow)              | Special Conditions*                                                                                                                                                                   |
| 1    | MSB of <i>dst</i>                          | 1 if $dst = 0$    | 0                       | 0                        | V flag is set when<br>expanded operand<br>type mode is used,<br>and the result is<br>truncated when<br>represented in<br>destination.                                                 |
| 2    | 1 if result $< 0$                          | 1 if result $= 0$ | 1 on carry<br>or borrow | 1 on integer<br>overflow | _                                                                                                                                                                                     |
| 3    | 1 if $dst < 0$                             | 1  if  dst = 0    | 0                       | 1 on integer<br>overflow | -                                                                                                                                                                                     |
| 4    | 1 if <i>dst</i> < 0                        | 1 if $dst = 0$    | 0                       | 1 on integer<br>overflow | V flag may not set<br>when $dst$ is signed<br>word type, bit 31 of<br>absolute value of the<br>result is 1, and while<br>bits 32-63 of the<br>absolute value of the<br>result are 0s. |

| Table 6-7. Condition Flag Code Assignments (Continued) |                      |                          |          |             |                                                                                                                                          |
|--------------------------------------------------------|----------------------|--------------------------|----------|-------------|------------------------------------------------------------------------------------------------------------------------------------------|
| C                                                      |                      | Condition                |          |             |                                                                                                                                          |
| Case                                                   | N(Negative)          | Z(Zero)                  | C(Carry) | V(Overflow) | Special Conditions*                                                                                                                      |
| 5                                                      | 1 if <i>dst</i> < 0  | 1 if $dst = 0$           | 0        | 0           | V flag is set if<br>expanded-operand type<br>mode changes the type<br>of <i>dst</i> and integer<br>overflow occurs.                      |
| 6                                                      | 1 if $src < 0$       | 1 if $src = 0$           | 0        | 0           | N flag is affected if <i>src</i> is signed integer.                                                                                      |
| 7                                                      | MSB of word returned | 1 if word returned $= 0$ | 0        | 0           | _                                                                                                                                        |
| 8                                                      | —                    |                          |          |             | All flags determined by new PSW.                                                                                                         |
| 9                                                      | _                    |                          |          |             | All flags determined by restored PSW.                                                                                                    |
| 10                                                     | _                    |                          | _        | _           | When coprocessor<br>status word is accepted,<br>bits $18-21$ of the word<br>read are put into bits<br>18-21 of the PSW,<br>respectively. |

Notes:

MSB – Most Significant Bit

dst – destination

src - source

\*For cases 1 through 6, when the PSW is used as a source the condition flags are unaffected; when the PSW is used as a destination, the condition flags assume the value of bits 18-21 of the result of the operation performed.



### CHAPTER 7. USING THE as ASSEMBLER

# CONTENTS

| 7. USING THE as ASSEMBLER                    |             |
|----------------------------------------------|-------------|
| 7.1 OVERVIEW OF ASSEMBLY PROCESS             |             |
| 7.2 as ASSEMBLER                             |             |
| 7.2.1 Assembled Files                        | ********    |
| 7.2.2 Diagnostics                            |             |
| 7.3 ASSEMBLER DIRECTIVES                     |             |
| Location Counter                             | *********** |
| 7.3.1 Section Control Pseudo-Operations      |             |
| 7.3.2 Pseudo-Operations Dealing With Symbols |             |
| 7.3.3 Assignment Pseudo-Operations           | ·····       |
| 7.3.4 Assignment to Dot                      |             |
| 7.3.5 Alignment Pseudo-Operations            |             |
| 7.3.6 Data Generation Pseudo-Operations      |             |
| 7.3.7 Symbolic Debugging Pseudo-Operations   |             |
| 7.3.8 File Name Pseudo-Operations            |             |
| 7.3.9 Line Number Pseudo-Operations          |             |
| 7.4 MACRO PROCESSING FACILITIES              |             |
| 7.4.1 Interface Macros                       |             |
| Function Interface Macros                    |             |
| Scratch Register Macros                      | ****        |
| Stack Frame Macros                           |             |
| Restrictions                                 | ********    |
| 7.4.2 Using Predefined Macros                |             |
| Examples                                     | •••••       |
| 7.4.3 M4 Reserved Words                      | ····        |

#### 7. USING THE as ASSEMBLER

This chapter describes the assembler (as). The assembler constructs an object file from an assembly language source file. The object file is relocatable and may include an extensive symbol table for symbolic debugging. This relocatable object file is in common object file format (coff).

The assembler translates operation code mnemonics and operands into the target machine bit pattern representing the particular instructions. The **as** assembler attempts to optimize the size of branch instructions, thus reducing the number of machine cycles required for a given task and improving program speed.

The assembler resolves local text labels, identifies global text symbols defined in the input files, and identifies symbols referenced but not defined.

#### 7.1 OVERVIEW OF ASSEMBLY PROCESS

Figure 7-1 shows an overview of the assembly process. In this process the assembler source (i.e., assembly language program) is passed to the **as** assembler to create relocatable object modules. The object modules are passed to the link editor (**ld**) along with any necessary run time libraries to create an executable object module. The **ld** link editor command is described in the C Programming Language Utilities for the 3B2/3B5/3B15 Computers.

#### 7.2 as ASSEMBLER

The assembler is called with the command line

#### as options filename

where filename ends with .s and options are chosen from Table 7-1.

| Table 7-1. as Command Line Options |                   |                                                                  |  |  |
|------------------------------------|-------------------|------------------------------------------------------------------|--|--|
| Option                             | Argument          | Description                                                      |  |  |
| G                                  | None              | Compares floating point numbers disregarding unorderedness.      |  |  |
| —m                                 | None              | Invokes the m4 macro processor.                                  |  |  |
| —n                                 | None              | Turns off long/short address optimization.                       |  |  |
| -0                                 | objfile           | Places the assembled output in objfile.                          |  |  |
| -R                                 | None              | Removes input when done.                                         |  |  |
| -U                                 | None              | Removes unreferred symbols.                                      |  |  |
| -V                                 | None              | Prints the version of the assembler being run on standard error. |  |  |
| -Y                                 | Directory<br>Name | Specifies alternative directory to find m4.                      |  |  |

#### USING THE as ASSEMBLER as Assembler



**Figure 7-1. Assembly Process** 

The input assembly language program is read from *filename* and the output is written to an output object file. Unlike cc, only one file at a time may be input to as. If the output file name is not specified by the -o option, the outpuame is created from *filename* using the following algorithm:

- If *filename* ends with the two characters .s, the output name is created by replacing these last two characters with .o.
- If *filename* does not end in .s and is no more than twelve characters in length, the output name is created by appending .o to *filename*.
- If *filename* does not end with .s and has more than twelve characters, the output name is created by appending .o to the first twelve characters of *filename*. (File names on the UNIX Operating System can be no longer than fourteen characters).

Usage of the assembler options entails a few potential pitfalls. If the -n option is not used, address optimization is invoked. The **.align** assembler directive is not guaranteed to work in a **.text** section when optimization is performed. Therefore, aligned constants should not be defined in the **.text** section. See 7.3 Assembler Directives for a more detailed description of **.align**.

#### 7.2.1 Assembled Files

The output of the assembler is an object file. Each assembled file contains three sections: .text, along with optimal .data, and .bss sections. Each section begins at an address that is a multiple of four and consists of a contiguous sequence of bytes. The .text section is used for executable statements, the .data section is used for initialized variables, and the .bss section is used for uninitialized variables. Every statement in the input assembly language that produces code or data generates it into one of these sections.

The assembler maintains three location counters for each assembled file, one for each of the program sections. The initial value of each counter is set to zero. When an assignment is made to the corresponding program section, the assembler increments the appropriate location counter. On its final pass, the assembler concatenates the three sections for each file in the order .text, .data, and .bss and sets each location counter to the correct starting address. That is, the text origin is set to zero, the data origin is set to the location that follows the .text section, and the .bss origin is set to the location that follows the data entry. Figure 7-2 shows these starting memory locations. Relocation of these sections is later done by the link editor (LD).

Because the assembler produces relocatable code, modular program development is possible and is encouraged.

#### 7.2.2 Diagnostics

Errors may occur when using the assembler. The assembler outputs an error message when an error occurs. The error messages are intended to be self-explanatory.

The most common error occurs when the input file cannot be read. The assembly then terminates with the message "Can't open *filename*". If assembly errors are detected in the input file, the following information is written to standard error: the input file name, the line number where the error occurred in the assembly code, and possibly a descriptive message for the problem.

#### 7.3 ASSEMBLER DIRECTIVES

An assembler directive is a command to the assembler that does not necessarily generate any code. Directives are distinct from executable instructions, which contain mnemonics for machine operations. Every assembler directive is coded as a pseudo-operation (pseudoop) code followed by zero or more operands. All assembler directives begin with a period (.). Table 7-2 lists all pseudo-ops alphabetically.



Figure 7-2. Mapping Program Sections

#### **Location Counter**

The symbol. (read as dot) is the location counter used during the assembly of a program and is reserved for use by the assembler. The type of this symbol is either TEXT, if code is currently being generated for the .text section, or DATA, if code is currently being generated for the .data section. The initial type of the location counter is TEXT and the initial value is zero.

The location counter represents the address of the next available byte for the placement of assembled code or data, and can change in the following ways:

- as a result of the .text, .data, .set, .zero, .align, .byte, .half, .word, .flt, or .double pseudoops
- as a result of the generation of code for a machine instruction.

In the first case, the change is explained in the description associated with each pseudo-op. In the second case, the location counter is incremented by the size of the assembled code *after* the statement is completely assembled.

For each section (.text, .data, or .bss), there exists a saved location counter value. Initially each saved location counter value is zero. When the programmer issues a section change pseudo-op, the current location counter (i.e., the section being changed from) is saved. The current location counter is then assigned the value of the location counter for the destination section.

#### 7.3.1 Section Control Pseudo-Operations

These pseudo-ops provide a method of changing the section in which code is generated and the section in which labels are defined. They work as follows: each of the sections .text, .data, and .bss has its own hidden dot or location counter that indicates where the next code is to be generated for that section. The actual symbol "." starts out with a type of TEXT and a value of zero. Whenever a section control pseudo-operation is encountered, the value of dot is stored away into whichever hidden dot is indicated by its type. The value of some other hidden dot is then retrieved and stored as the value of the symbol ".", and the type of dot is set depending on which hidden dot is used.

The following section control pseudo-operations are recognized:

.text .data .bss symbol,size,align .ident string

where:

- .text causes the current location counter to be saved and then assigned the value of the location counter for the text section. The type of the current location counter is set to TEXT.
- .data causes the current location counter to be saved and then assigned the value of the saved value of the location counter for the data section. The type of the current location counter is set to DATA.
- .bss causes the bss location counter to be advanced to a multiple of *align* (which must be an ABSOLUTE expression with a value of 2 or 4), and assigns to *symbol* the type BSS and the current value of the bss location counter. The *.bss* section then advances its dot by the value of *size*. The symbol *size* refers to the number of bytes; it must be greater than or equal to 0 and have type ABSOLUTE. The type and value of the current location counter remain unchanged.
- .ident causes the string argument to be placed into the .comment section in the object file. The object file is a nonloaded type information section.

#### USING THE as ASSEMBLER Section Control Pseudo-Operations

| Table 7-2. Alphabetical List of Pseudo-Operations |                                                                                                                                                                                                                                                                                                                                            |  |  |
|---------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Name                                              | Operation                                                                                                                                                                                                                                                                                                                                  |  |  |
| .align expr                                       | Increments the current location counter to a multiple of <i>expr</i> ; <i>expr</i> must evaluate to an ABSOLUTE of 2 or 4.                                                                                                                                                                                                                 |  |  |
| .bss sym, size, align                             | Defines the symbol name <i>sym</i> in the <b>.bss</b> section, and add<br><i>size</i> to the value of dot and <b>.bss</b> after aligning it to a<br>multiple of <i>align</i> . This does NOT change the current<br>section to <b>.bss</b> ; <i>size</i> must be an ABSOLUTE value and <i>align</i><br>must be an ABSOLUTE value of 2 or 4. |  |  |
| .byte val[, val]                                  | Generates initialized bytes containing the 8-bit value val in the current section.                                                                                                                                                                                                                                                         |  |  |
| .common name,expr                                 | Reserves <i>expr</i> bytes of uninitialized storage for symbol name.                                                                                                                                                                                                                                                                       |  |  |
| .data                                             | Changes the current section to .data.                                                                                                                                                                                                                                                                                                      |  |  |
| .def name                                         | Start of the symbolic description for the symbol name.                                                                                                                                                                                                                                                                                     |  |  |
| .dim expr[, expr]                                 | If the <i>name</i> in .def is an array, then the expression gives the dimensions. Up to five dimensions are accepted. The type of each expression should be ABSOLUTE.                                                                                                                                                                      |  |  |
| .double val                                       | Generates the 64-bit floating point representation of val.                                                                                                                                                                                                                                                                                 |  |  |
| .endef                                            | Ending bracket for .def.                                                                                                                                                                                                                                                                                                                   |  |  |
| .file "name"                                      | Passes the UNIX System source file name to the assembler.<br>Only one .file is allowed per assembly file.                                                                                                                                                                                                                                  |  |  |
| .float val                                        | Generates the 32-bit floating point representation of val.                                                                                                                                                                                                                                                                                 |  |  |
| .global name                                      | Treats <i>name</i> as a global symbol, equivalent to storage class <i>extern</i> in the C language.                                                                                                                                                                                                                                        |  |  |
| .half val[, val]                                  | Generates initialized halfwords containing val in the current section. Each val must be a 16-bit value.                                                                                                                                                                                                                                    |  |  |
| .ident "string"                                   | Places the null terminated string "string" in the .comment section of the output file.                                                                                                                                                                                                                                                     |  |  |
| .il                                               | Indicates that a procedure has been expanded in line.                                                                                                                                                                                                                                                                                      |  |  |
| line expr                                         | Defines the source line number of the definition of block<br>symbol "name" in .def. expr should yield an ABSOLUTE<br>value.                                                                                                                                                                                                                |  |  |
| .In line[, addr]                                  | Creates an entry in the line number table for a section. The current dot becomes the default for <i>addr</i> . The type of <i>addr</i> tells which section owns the line number. The operand <i>line</i> should be an ABSOLUTE value of the source line number.                                                                            |  |  |
| .previous                                         | Changes the current section to the previous section. Only<br>one level of previous section is possible.                                                                                                                                                                                                                                    |  |  |
| .scl expr                                         | Within .def give name the storage class of expr. The type of expr should be ABSOLUTE.                                                                                                                                                                                                                                                      |  |  |

| Table 7-2.         Alphabetical List of Pseudo-Operations (Continued) |                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
|-----------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Name                                                                  | Operation                                                                                                                                                                                                                                                                                                                                                                       |  |  |
| .section sect_name, "sect_type"                                       | Creates a section sect_name in the output file, of types<br>sect_type, and change the current section to sect_name. A<br>section type may be one or more of the following:<br>b - bss section<br>c - copy section<br>i - info section<br>d - dummy section<br>x - executable (text) section<br>n - noload section<br>o - overlay section<br>l - lib section<br>w - data section |  |  |
| .set name,expr                                                        | Sets the value of the symbol <i>name</i> to <b>expr</b> ; <i>name</i> must be a symbol.                                                                                                                                                                                                                                                                                         |  |  |
| .size expr                                                            | If <i>name</i> of .def is an object such as a structure or an array, assign it size <i>expr</i> . The type of <i>expr</i> should be ABSOLUTE.                                                                                                                                                                                                                                   |  |  |
| .tag str                                                              | If <i>name</i> of .def is a structure or union, <i>str</i> should be the name of that structure or union tag as defined in the previous .defendef pair. The operand <i>str</i> must be a symbol.                                                                                                                                                                                |  |  |
| .text                                                                 | Changes the current section to .text.                                                                                                                                                                                                                                                                                                                                           |  |  |
| .type expr                                                            | Within a .def, give <i>name</i> the C compiler type representation <i>expr</i> . The type of <i>expr</i> should be ABSOLUTE.                                                                                                                                                                                                                                                    |  |  |
| .val expr                                                             | Within .def, give <i>name</i> the value <i>expr</i> . The type of <i>expr</i> should be ABSOLUTE.                                                                                                                                                                                                                                                                               |  |  |
| .version "string"                                                     | Identifies the minimum version of the assembler necessary to assemble the input file.                                                                                                                                                                                                                                                                                           |  |  |
| word val[, val]                                                       | Generates initialized words containing val in the current section. Each val must be a 32-bit value.                                                                                                                                                                                                                                                                             |  |  |
| .zero size                                                            | Advances the location counter by <i>size</i> and put zeros in the area skipped. The type of <i>size</i> should be ABSOLUTE. This pseudo-op is legal only in a .data section.                                                                                                                                                                                                    |  |  |

#### 7.3.2 Pseudo-Operations Dealing With Symbols

The pseudo-op .globi is used to declare that a symbol is to be accessed by more than one object module of a single program (i.e., given the EXTERNAL attribute). The format is:

#### .globl symbol

This statement has one of two effects:

• If symbol is defined in the program in which the .globl statement appears, a symbol table entry will appear in the object file that will allow other programs to access symbol.

• If symbol is not defined in the program in which the .globl statement appears, then references to symbol will be treated as references to something defined externally. This use of .globl is entirely optional since any symbol that is undefined in a program will be assumed to be external.

It is important to note that .globl does *not* define the symbol. This pseudo-operation is similar to the "extern" declaration in the C language. A symbol is defined either when it is used as a label, when it is used in one of the data generating operations, or when it is given a value in an assignment statement.

#### 7.3.3 Assignment Pseudo-Operations

A symbol may be given an arbitrary value and type through the use of the .set pseudo-op. It has the form:

#### .set symbol, expression

The expression (see 3.4 Expressions) is evaluated and its value and type are assigned to symbol. Every symbol that appears in expression must either be defined or have the EXTERNAL attribute.

Assignments are performed during the assembler's first pass over the input program. This procedure has several important consequences:

- The .set pseudo-op does not allow forward referencing, i.e., every symbol that appears in *expression* must be defined prior to the assignment statement. Forward references are allowed in other contexts because all other expressions are not evaluated until later passes.
- The result of the assignment may be different from the expected result. For example, consider the assignment

#### .set abc, lab1 -- lab2

where *lab1* and *lab2* are labels appearing in the .text section. An ABSOLUTE value is assigned to *abc*, which is the distance from *lab2* to *lab1*, during the first pass. This distance may change during subsequent passes if there are offsets between *lab2* and *lab1* that need to be altered. For example, the jmp instruction can assemble into a short form (2 bytes) or a long form (3 bytes) depending on the value of the offset. The first pass of the assembler assumes that the 2-byte form can be used. This will be expanded to the 3-byte form if a subsequent pass determines that the label is out of the range for a short jump. This expansion will not be reflected in the value of *abc* if the jmp occurs between *lab1* and *lab2*.

Other assignments may have no problem at all. For example, expressions containing only ABSOLUTE operands always yield the correct result. Assignments such as

.set xyz,lab1

where *lab1* is a label in the .text section, also behave as desired. When code is modified, the assembler changes the values of labels to point to the correct locations. If the value of

*lab1* changes, so will the value of xyz, because both are TEXT symbols with the same value.

#### 7.3.4 Assignment to Dot

Null data may be generated by assignment to the location counter. The location counter is represented by the dot symbol (.). Assignment to dot may be performed under the following conditions:

- The result type of the expression to be assigned to dot has the same type as dot.
- The value of the expression to be assigned is not less than the value of dot.

If the assignment increases the value of dot by N, then N bytes of null data are generated. Assignment to dot is most often used to provide holes or spaces in code. For example, the

.set .,.+10

generates 10 bytes of null data. The assembler defines null data in the .text section as NOPs (0x70); null data in the data section is zero.

#### 7.3.5 Alignment Pseudo-Operations

The alignment pseudo-op .align causes the next data item or instruction to be assembled at an address that is a multiple of 2 or 4. It has the form

#### .align expression

where *expression* must evaluate to an ABSOLUTE 2 or 4. A .align 2 causes the value of current location counter to be incremented by one if its current value is not a multiple of 2. A .align 4 causes the value of the current location counter to be incremented by one, two, or three, if its current value is not a multiple of four. The appropriate increment (one, two, or three) needed to bring the location counter to a multiple of four is chosen. If this directive is used in the .text section, any space skipped will be filled with NOP instructions. If it is used in the .data section, any space skipped will be filled with zeros.

#### 7.3.6 Data Generation Pseudo-Operations

Data generation pseudo-ops are used for declaring variables. The data generation pseudooperations – .byte,.half, and .word generate 8-, 16-, and 32-bit integer constants, respectively, while the pseudo-ops – .fit. and .double generate 32- and 64-bit floating point constants, respectively. The forms are:

.byte expr, ... .fit expr, ... .half expr, ... .double expr, ... .word expr, ... Each expression will be converted into its respective data type. The location counter must be properly aligned with .align before each use of one of these pseudo-ops. Dot is then incremented by one, two, or four (depending on the pseudo-op) after the generation of each data item in the list of expressions for that statement. For example, .word .,.., generates three words of data and each word contains the address of the first byte of that word. Therefore, each word contains a different value.

Each expression may be given a bit width by prefacing it with an integer constant followed by a colon. This format for bit width is

n:expr

where n ranges from 0 to 8 for .byte, 0 to 16 for .half, and 0 to 32 for .word. Nonprefaced expressions have an assumed bit width of 8, 16, or 32, depending on whether the .byte, .half, or .word pseudo-op is used. The expression, which must be ABSOLUTE, is converted into the proper representation and placed in a field of the indicated width.

For example,

*mode*: .byte 5:x+y, 3:0

initializes an 8-bit variable, mode, by setting the upper five bits of mode to the result of the expression x + y, and the lower three bits to zero.

Fields are assigned from high order bit positions (i.e., bit 7 of a byte) to low-order bit positions. Each successive expression is placed into a field that begins with the next lower bit position. The location counter is adjusted after the generation of each data item; it always indicates the address of the first *byte* into which the current data item is to be placed.

A field is not allowed to cross the implied boundary indicated by one of the above pseudoops. If too few fields are encountered to fill the indicated unit of memory, enough zeros are supplied to fill the low order bits.

The data generation pseudo-op .zero allocates an area of memory and fills it with zeros. It has the form

.zero size

where *size* is the number of bytes to allocate and fill with zeros. The .zero pseudo-op advances the location counter by *size* and puts zeros in each byte of memory that is skipped. It is legal only in the .data section. Variables declared static in a C source program are assembled through this pseudo-op.

#### 7.3.7 Symbolic Debugging Pseudo-Operations

Symbolic debugging pseudo-ops are provided for making entries in the symbol and line number tables in the object file. The presence of symbolic debugging pseudo-operations in an assembly language program has no effect on program execution. These statements merely serve to transparently pass information from the user code to the symbolic debugger. The basic symbolic debugging pseudo-operations are .def and .endef. These are used as a pair to surround a list of pseudo-operations that assign attributes to a symbol. The format used is:

### .def name

{Attribute-assigning pseudo-operations}

.endef

The attribute-assigning pseudo-operations between .def and .endef assign attributes to the symbol *name*. These attribute-assigning pseudo-operations are available:

| .val expr         | Gives the value <i>expr</i> to the symbol <i>name</i> . In general, the type of <i>expr</i> (TEXT, DATA, etc.) is used to determine the section with which the symbol <i>name</i> is associated.                                                                                                     |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| .scl expr         | Declares a storage class for the symbol <i>name</i> . <i>expr</i> must yield a value of ABSOLUTE type that corresponds to one of the values in the C leader file storeclass, h.                                                                                                                      |
| .type expr        | Declares a data type for the symbol <i>name</i> . <i>expr</i> must yield a value of ABSOLUTE type that corresponds to the value of type and derived type in the header file syms, h.                                                                                                                 |
| .tag str          | Used when <i>name</i> is a C level structure or a union. <i>str</i> is a structure or union tag that is defined by some other <b>.defendef</b> pair.                                                                                                                                                 |
| .line <i>expr</i> | Used when <i>name</i> is a block symbol. <i>expr</i> yields a value of ABSOLUTE type that gives the line number of the declaration for <i>name</i> .                                                                                                                                                 |
| .size expr        | Used when <i>name</i> is a C level structure or an array that does not have a predetermined size. <i>expr</i> should yield a value of ABSOLUTE type that gives the size of <i>name</i> , usually in bytes, or in bits if <i>name</i> is a bit field.                                                 |
| .dim expr1,expr2, | Used when <i>name</i> is an array. Each expression yields a value of ABSOLUTE type that gives the corresponding dimension of the array. Since the UNIX System implementation of the C language supports up to five dimensions for an array, there may be up to five arguments to the .dim pseudo-op. |
| .il               | Used to indicate that a procedure has been expanded in-line.                                                                                                                                                                                                                                         |

For symbolic debugging purposes, the order of symbols is very important. The assembler has no knowledge of this ordering; it just passes the symbols through from the C compiler so they may be accessed by the symbolic debugger.

As with **.globl**, the **.def** pseudo-op does not define the symbol. A symbol table entry is created but no definition occurs.

#### 7.3.8 File Name Pseudo-Operation

Associated with each assembly file can be at most one .file pseudo-op. It has the form

.file "name"

where "name" is a double-quoted string of 1 to 14 characters. This pseudo-op is normally used to pass the name of the C source file from which the assembly program originated. name then becomes part of the symbol table and can be accessed at run time.

#### 7.3.9 Line Number Pseudo-Operations

Each section in the object file has a line-number table associated with it that maps line numbers in the source code to addresses within the section. A line-number entry may be made using the .In pseudo-operation as:

.In line[,value]

The operand *line* must have a value of ABSOLUTE type that gives a line number in the source code. The optional operand *value*, if present, must have a value of type TEXT, DATA, or BSS that gives the address within the section where the line number occurs. If the *value* operand is missing, the value of the current location counter will be used as the address of the line number.

#### 7.4 MACRO PROCESSING FACILITIES

Macro processors enhance programming languages by making them more readable or by tailoring them to specific applications. The basic facility provided by any macro processor is replacement of text by other text.

When the  $-\mathbf{m}$  option of **as** is specified, the M4 processor is invoked. The M4 macro processor provides a collection of about thirty-two built-in (default) macros; in addition, the user can define new macros using the M4 **define** function. As part of the programming environment provided by the Software Generation Utilities, many interfacing macros have been predefined. That is, the **define** function of M4 has already been used to establish several macros that interface assembly language routines with C code.

The M4 processor operates by copying its input to its output. As the input is read, each alphanumeric token (i.e., string of letters and digits) is checked. If the token matches the name of a macro, the name of the macro is replaced by the defining text and the resulting string is pushed back onto the input and rescanned. In M4, built-ins and user-defined macros work exactly the same way, except that some of the built-in macros have side effects on the state of the process. Macros may be called with arguments, in which case the arguments are collected and substituted into the right places in the defining text before that text is rescanned.

Use of the M4 helps facilitate symbolic debugging when assembly code is used by tailoring the input file to look as though it came from the compiler. When an assembly language program uses the provided M4 macros, symbol table information can be generated, as well as the prologue and epilogue pseudo-code sequences that the compiler normally provides. The assembly language programming example demonstrates the prologue and epilogue sequences.

#### 7.4.1 Interface Macros

A set of predefined macros is provided to enable assembly language function linkages to C code to be specified independently from the details of the calling sequence. The macros, therefore, not only make programming easier; they also provide some insulation from any changes to the calling sequence that may occur.

When the  $-\mathbf{m}$  option is used, M4 preprocesses all input assembly language source files. The macros described below are made available as part of this preprocessing step. The M4 processor operates on both assembly language source files and on intermediate assembly language files generated by the compiler for C source files (i.e., .c files) that contain *asm* assembler escapes.

Note: When using as, the -m option can be specified on the command line. When using cc, the -Wa, -m option must be specified to access the macro package.

#### **Function Interface Macros**

The M4 macro package uses a functional notation for macros with arguments. Function interface macros should appear alone on a line with the arguments enclosed in parentheses and separated by commas. Additional white space (blanks and tabs) is ignored. Macros without arguments should appear in the assembly text just as if they were normal assembly language expressions.

#### C\_PROLOGUE(name[,nregs])

This macro generates the standard C function prologue that finishes saving the caller's environment on the stack and sets up a new stack frame for use by the called routine. The *name* must be a valid C language identifier.

The optional argument *nregs* gives the number of C language register variables that are saved by C\_PROLOGUE (default is six registers). The assembly language function may use the saved registers for any purpose. Register variable arguments and stack arguments are not available to C\_PROLOGUE. Another predefined macro, \_RESULT, names the register that must be loaded with any value to be returned to the calling function.

#### C RETURN(nregs)

This macro generates the standard function return sequence. It restores the caller's environment and executes a branch to the return address that was saved with the environment on the stack at the time of the call. The number of registers to be restored is given by *nregs* and should be the same as that specified in **C\_PROLOGUE**. The default is six.

#### C\_CALL(func[,arg1,...,arg5])

This macro generates a call to the C language function func. The operand func must be a

valid function name for either another normal assembly routine or a C source function that has become known by link editing. Up to five arguments can be passed with C\_CALL. The arguments can be any valid operands to the assembler **pushw** instruction. Note that the function arguments are passed through without change (except for macro expansion). In the assembler language syntax, a variable name or constant operand is normally treated as if addressing a word in memory. The ampersand (&) can be used to show that the address itself is wanted. Thus, to use a specific value as an argument, an ampersand is used with the value. For example, the value 3 would be designated by &3. An argument that is to be the value stored at some address is indicated by giving the address with no ampersand. For instance, to obtain the contents at address x, designate the letter x. If the address itself is to be used as the value, write the value as an ampersand address; e.g., designate address x by &x.

#### A **PROLOGUE**(*name*)

This macro operates the same as C\_PROLOGUE, but does not allow any registers to be saved.

#### A\_EPILOGUE(name)

This macro generates the symbolic code indicating the end of a function. Programmers must still write the actual return instructions before the A\_EPILOGUE macro call; e.g., **RESTORE** and **RET**.

The macros that begin with C were written to connect assembly language segments to C language programs. However, they can also be used to connect two assembly language segments. In this use, the macros provide symbol table definitions, beginning and ending statements, and a save instruction for the new segment.

If only the symbol table definition and the beginning and end statements are needed, the A\_PROLOGUE A\_EPILOGUE pair should be used. The pair does not contain a save command, and its use requires explicit coding of save and return instructions.

#### Scratch Register Macros

The C compiler uses three scratch registers to store temporary results of expression computations. When the compiler processes a function call, it guarantees that no current values in the scratch registers will be needed after the call (by storing the values in temporary locations on the stack if necessary). Therefore, each function is free to use the scratch registers in any way and does not have to save or restore them. The macros **SCR1**, **SCR2**, and **SCR3** expand to the register numbers of the scratch registers and may be used freely inside a normal assembly language routine. Note that **SRC1** names the same register as **RESULT**. Register **SCR1** has special meaning during the call and return sequence, but is available for general use inside the called function.

#### Stack Frame Macros

Stack frame macros start with an underscore (\_) and provide access to the current stack frame environment. The argument macros \_1STARG, \_2NDARG, \_3RDARG, \_4THARG, and \_5THARG reference the first through fifth arguments to the function (via memory

address), respectively. The macros \_1STREG, \_2NDREG, \_3RDREG, \_4THREG, \_5THREG, and \_6THREG reference the six general-purpose registers, r8 through r3, respectively. The macro \_RESULT references the register (typically r0) used by the C compiler to contain the value returned from a function.

If these macros are used in a normal assembly language routine (for example, one that uses C\_PROLOGUE and C\_RETURN), they refer to the stack frame set up by C\_PROLOGUE. Note that C\_PROLOGUE does not allocate any automatic storage.

The C stack frame can also be accessed directly by the stack pointer register (SP, r12), the frame pointer register (FP, r9), and the argument pointer register (AP, r10). The function interface and stack frame macros track any changes in the calling sequence. If the SP, FP, or AP registers are used to get closer to the stack frame layout, code will no longer be insulated from the details of the stack frame, and may have to be rewritten later.

#### Restrictions

In effect, the argument and register macros independently follow the same algorithm used by the C compiler to allocate storage. Because there is no way for the macro processor to know about the real environment of the assembly function or calling function, the following restrictions must be considered when using these macros:

- The use of argument and register macros is inherently machine-dependent; the macros cannot be recognized by processors not based on the assembler.
- All arguments, up to and including the last argument referenced by the macros, must be ints or pointers. These macros do not deal with char, short, or struct arguments. Functions that return structures require a more complicated calling sequence that is not handled by this macro package.
- For assembly language routines, any copying of arguments into registers must be done explicitly by the assembly code.
- Macro usage is not checked during the compiling and assembling of programs. Therefore, an assembly language routine that incorrectly changes the value of FP will cause run-time errors rather than compile-time errors.

#### 7.4.2 Using Predefined Macros

A normal assembly language routine is called from a C source program just like any other function. The routine can have arguments passed to it and it establishes its own environment on the stack. The file containing the assembly language source must have a name ending in .s. The .s tells the compiler (cc) to skip compilation and send the source directly to the assembler.

#### Examples

In the following example, a function named bump adds one to its argument and returns that result.

C\_PROLOGUE(bump)

#### **USING THE as ASSEMBLER** Examples

#### movw **1STARG,% RESULT** addw2 &1,% RESULT

#### **C RETURN**

ł

}

ł

]

If bump were called by the following C language routine

```
main()
             int i = 3;
             int j;
             i = bump(i);
```

then j would have the value 4, while i remains unchanged.

The next example gets two pointers as arguments and swaps the values pointed to:

C PROLOGUE(swap) movw 1STARG,%\_1STREG #1st arg is a pointer movw 0(% 1STREG),% SCR1 #get value pointed to movw 2NDARG,% 2NDREG #2nd arg is also a pointer movw 0(% 2NDREG),% SCR2 #get its value movw % SCR2,0(% 1STREG) #store 2nd args value movw % SCR1,0(% 2NDREG) #store 1st args value **C RETURN** 

Suppose swap was called by the following program

then i would get the value -4 and j would get the value 3. A C language function to accomplish the same task is

\*i = \*j; \*j = temp;

In the final example, assembly function *chkster* checks to see whether, after skipping the first character, a text string has a common prefix with the string "abcdef," using the function *prefix*. This is a contrived example that has no place in real code, but is presented to demonstrate how a C language function is called with the C\_CALL macro.

#### C PROLOGUE(chkstr)

addw3 &1,\_1STARG,%\_SCR1 #skip first character C CALL(prefix, & string, % SCR1)

#### **C RETURN**

.data

string:

}

.byte 0x61,0x62,0x63,0x64,0x65,0x66,0x0

Note: The address of the format string must be passed to *prefix* and that the null byte terminating the string must be explicitly coded. Also, unlike some implementations, the cc compiler does not prepend an underscore before global names. Thus, *prefix* is used in assembly code, not *prefix*.

#### 7.4.3 M4 Reserved Words

Detailed discussion of the M4 processor can be found in the UNIX System User's Manual. A list of the M4 reserved words is:

| changecom   | ifdef    | shift    |
|-------------|----------|----------|
| changequote | ifelse   | sinclude |
| decr        | include  | substr   |
| define      | incr     | sysemd   |
| defn        | index    | sysval   |
| divert      | len      | traceoff |
| divnum      | m4exit   | traceon  |
| dnl         | m4wrap   | translit |
| dumpdef     | maketemp | undefine |
| errprint    | popdef   | undivert |
| eval        | pushdef  |          |
|             |          |          |

| And the second second                    | 11 2.1 A 12 M                            | And a second      |                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | - A - A - A - A - A - A - A - A - A - A                                                                          |
|------------------------------------------|------------------------------------------|-------------------|-----------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|
| - CAN 19 - CAN                           | \$5.70 × 12 \\ \$64                      |                   | Section 2.                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | <u> </u>                                                                                                         |
|                                          | m16r - 12 16r                            | (* 1 S. 1 S. 2 S  | And in the later.                                                                                               | - 1961 - 1965 - 19                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                  |
| New Artest                               | (の) マイ・ウト (の)                            |                   |                                                                                                                 | - <b>- 14</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                  |
|                                          | e 6 16 18 16 6                           | 1 C 1 C 1 C 1     |                                                                                                                 | 1 C 1 C 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                  |
|                                          | en woor over                             |                   |                                                                                                                 | 100 C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                  |
| STOCKED AND A                            | 200 1 2 2 2 2 2 2                        | en de la co       | 101 B 1 C 1                                                                                                     | - 42.5° - 1.1 - 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 1 1 2 N 1 1                                                                                                      |
| Same Strate                              | 200 A 200                                | Sec. Sec.         | 3 C ( 12                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                  |
| SN 80 - 245 - 51                         |                                          |                   | um 4. di.                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                  |
| 3 - A Star Star Star Star                | Contraction of the                       |                   |                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                  |
| 1999 (Million &                          |                                          |                   | - 10 M M M M                                                                                                    | or Spiriteger G                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                  |
| CONTRACTOR OF                            |                                          | 10.000            | The second se | 1999 C 1999 C 1999                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                  |
| になるれたいできょう                               |                                          | الالودية فرزة     | 日本語ないの名称                                                                                                        | Contraction of the second                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 120.00                                                                                                           |
| 100 C 20 C 20 C                          | 1999 - NY 1999 - NY 1999                 |                   |                                                                                                                 | ST 1991 A.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | $\mathbf{n}$                                                                                                     |
| Conta de Central a                       | S. 14 1-236                              |                   | . 68 A 1990A                                                                                                    | N N 9 13                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                  |
| 122.2993414.49                           | 1444 B. S. S. C. S.                      | 89 - C N.S C      |                                                                                                                 | S. 1996 & 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | See 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.                                                                       |
| 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1 | . 88 a. 202                              | S. 44 . 1999      | 3.2204                                                                                                          | 1011 St. 24                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Sec. 3. 255                                                                                                      |
| CONTRACT.                                | 1911 S.D. (1994)                         | W 14 1 A 17 2 A 1 |                                                                                                                 | 2028489119                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 20 A.C.                                                                                                          |
| ないがっこうわ                                  | - A. C. M. 1973                          |                   |                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                  |
| 2010-11-22                               | er de la constante                       |                   | 영화 도구는                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | <ol> <li>Contract</li> </ol>                                                                                     |
| 2748480278                               | Sec. 2 Sugar carriers                    | C. Makery         | 10.00 Lat. 50                                                                                                   | - CC 200                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | a second and a second |
| 32.6                                     | GAS - CO - AN                            |                   | States and                                                                                                      | SERV & 13                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | C 84 (                                                                                                           |
| -368 - 1986 - 1                          | 10 1 1 C 1 1 2 1                         | ti Berthel        | 1992 A. O                                                                                                       | S 2 S 1 S 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Sec. 1.                                                                                                          |
| 12 The Later 1                           |                                          | 소 국민이 같아.         | 이야 한 것이 같아요.                                                                                                    | 100 C 100 C 100                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1923 - U.S.                                                                                                      |
| "State of the Share                      | 1118 (D.N. 6. 1991)                      | Sec. Sec. Sec.    | - C.C. 125-04                                                                                                   | 1. 10 Mar 199                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 2001.01                                                                                                          |
|                                          | en og det                                |                   |                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                  |
| San CONSTRACT                            |                                          |                   | 엄마나 감다.                                                                                                         | 2018 o de 186, é                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                  |
| 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1 | SC 25 32                                 | Galace 2003.      | 1 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.                                                                        | and the second sec |                                                                                                                  |
| 七本(34) 256-23                            | • الطبل الشكة الا                        | مدة يتثلا الشا    | Sale and the second                                                                                             | Sec. 6. 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | - کار الصفقا                                                                                                     |
| - AND - AND - A                          |                                          |                   | 10 0 0 1                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                  |
| 1 Starting 1, 5, 5, 7, 1                 | 1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1. |                   | ~                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Sec. 1.120.                                                                                                      |
| 10.54 6.54 73                            |                                          | 1 C 1 C 1 C 1     | 法案 医胃炎                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | A 🖬 🚽 🖓 👉 👘                                                                                                      |
| Second St.                               | - C. |                   | 10. 20                                                                                                          | 200 C C C C C C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                  |
| Section of the                           | 이 집 같은 날카운                               | Charles and Cold  |                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                  |
| 经保证 计存储器                                 |                                          | Sector Sector     | 20130-000-0                                                                                                     | and States and                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                  |

## CHAPTER 8. THE dis DISASSEMBLER

### CONTENTS

| 8. THE dis DISASSEMBLER.            | 8-1 |
|-------------------------------------|-----|
| 8.1 INVOKING THE DISASSEMBLER       | 8-1 |
| 8.2 DISASSEMBLY LISTING             | 8-2 |
| 8.2.1 Using the Disassembly Listing | 8-3 |
| 8.3 ERROR MESSAGES                  | 8-3 |
|                                     |     |

#### 8. THE dis DISASSEMBLER

The dis disassembler utility produces an assembly language listing for each object file specified as input. The listing has a two-column format; assembly language statements are in the right column and the corresponding hexadecimal object code and machine address of the code are in the left column.

The disassembler produces a facsimile of the assembly language file that was assembled to produce a given object file. The **dis** provides a convenient method of obtaining a processor assembly language listing of C language source programs and for assembly language programs written in assembler code.

#### 8.1 INVOKING THE DISASSEMBLER

To invoke the disassembler, enter the command line

dis options files

where options are chosen from Table 8-1 and *files* represents a list of object files. If no options are specified, all sections containing text are disassembled.

| Table 8-1. m32dis Command Line Options |          |                                                                                                                                                                                                                                               |  |  |
|----------------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Option                                 | Argument | Description                                                                                                                                                                                                                                   |  |  |
| d                                      | section  | Disassembles the named section as data and prints<br>the offset of the data from the beginning of the<br>section.                                                                                                                             |  |  |
| -da                                    | section  | Disassembles the named section as data and prints the actual address of the data.                                                                                                                                                             |  |  |
| -F                                     | function | Disassembles single named functions in each object file that is specified on the command line.                                                                                                                                                |  |  |
| -L                                     | None     | Invokes a lookup of C source labels in the symbol table for subsequent printing.                                                                                                                                                              |  |  |
| -1                                     | string   | Disassembles the library file specified by string.<br>For example, one would issue the command line<br>dis $-1 \times -1 \ge 10$ disassemble the libraries libx.a<br>and libz.a. The libraries are assumed to be in the<br>SGP lib directory. |  |  |
| -0                                     | None     | Prints numbers in octal; without this option, default is hexadecimal.                                                                                                                                                                         |  |  |
| <b>—s</b>                              | None     | Disassembler in symbolic format.                                                                                                                                                                                                              |  |  |
| -t                                     | section  | Disassembles the named section as text.                                                                                                                                                                                                       |  |  |
| - <b>V</b>                             | None     | Prints the version number of the disassembler being executed.                                                                                                                                                                                 |  |  |

Note: Arguments are appended to options with no embedded blanks, except for the -1 option.

The -d option causes the named section of the object file to be disassembled as a data section. The object code and its address relative to the beginning of the section are listed. The **dis** makes no attempt to determine the corresponding assembly language statement. Addresses relative to the beginning of the named section are printed on the left side; object code bytes are printed on the right side, eight bytes per line.

The -da option causes disassembly of the named section of the object file as a data section. The object code and its absolute addresses are listed. No attempt is made to determine the corresponding assembly language statement.

If the -F option is used, only those named functions from each file will be disassembled.

The -t option causes the named section of the object file to be disassembled as a text section. The listing consists of the object code, its machine address, and the assembly language statements that produced the code. For example, if the command line is

**dis** −*t* section files

then the bytes of that section of object code are assumed to be opcode and operand encodings. The opcodes are looked up in the opcode disassembly table and the operands are disassembled and printed.

#### 8.2 DISASSEMBLY LISTING

This section gives an sample disassembly listing and describes how it is interpreted. Three features of the **dis** listing are:

- 1. The disassembler prints line numbers for each C source line where a breakpoint can be set in square bracket (e.g., [5] shows the fifth source line where execution can be halted for debugging). The line numbers appear in the first column, on left hand side of the instruction corresponding to the line where a breakpoint can be inserted.
- 2. The disassembler, if the -s option is specified, prints C function names followed by parentheses (e.g., printf() for the function printf). The function names appear in the first column, one line above the instruction that begins the function.
- 3. The disassembler prints computed addresses within a section when control is to be transferred to those addresses. They are printed within triangular brackets (e.g., <40> is computed address 40). These addresses appear in the operand field of control transfer instructions following a relative displacement. The computed address is the sum of the relative displacement and the address of the instruction currently being disassembled.

Note that items 1 and 2 occur only if the information exists in the object file (e.g., the code was compiled by cc with the -g option and the information was not removed by a utility or link editor option).

#### 8.2.1 Using the Disassembly Listing

(Information to be supplied.)

#### 8.3 ERROR MESSAGES

Error messages are output when the disassembler encounters any misuse. The messages are intended to be self-explanatory.

Chapter 9 Operating System Interface

### CHAPTER 9. OPERATING SYSTEM INTERFACE

### CONTENTS

| the second second second |                            |                       | 常儀   |
|--------------------------|----------------------------|-----------------------|------|
| 9. OPERATING SYSTEM      | I INTERFACE                |                       | ŝ    |
| 9.1 FEATURES OF THE      | <b>OPERATING SYSTEM</b>    |                       | 1.28 |
| 9.1.1 Memory Managemen   | t Considerations for Virtu | al Memory Systems 9-4 |      |

#### 9. OPERATING SYSTEM INTERFACE

The WE 32100 Microprocessor allows cost-effective design of operating systems by providing the system designer with special-purpose operating system instructions and an architecture that supports process-oriented operating system design. In general, a process is a separately scheduled, independently executed unit of activity. It generally consists of routines (functions) that perform a major task (such as a program manager, a file manager, or a memory manager). To make full use of the power of the WE 32100 Microprocessor as an execution vehicle for today's efficient process-oriented operating systems, this chapter presents the operating system considerations important to the system designer.

The typical operating system for the WE 32100 Microprocessor schedules and initiates all processes, handles error conditions (*exceptions* to normal processing), provides system security, and resets the microprocessor when appropriate. Processes are scheduled through common scheduling algorithms and are initiated through a *process switch*. A process switch is an explicit or implicit request that changes the process controlling the microprocessor. An explicit process switch is invoked by execution of one of the special operating system instructions. An implicit process switch occurs as a result of a reset request, some interrupt requests, or certain exception conditions. In theory, the microprocessor can handle an unlimited number of processes, but real limits are imposed by the operating system design (i.e., limiting the size of the interrupt stack). System security is enforced by the microprocessor and by the WE 32101 Memory Management Unit (MMU), an integral part of a virtual memory-based operating system using the WE 32100 Microprocessor. The microprocessor is reset by the operating system through a reset exception handler process. This handler should initialize the system hardware and reload the operating system.

#### 9.1 FEATURES OF THE OPERATING SYSTEM

As part of its architecture, the microprocessor provides four execution or access levels for processes. This allows each process to have functions that operate at different levels to provide the proper levels of system protection. These levels range from the *most privileged* (level 0) to the *least privileged* (level 3). Through built-in microprocessor safeguards, the privilege level serves as a protection level. One of the functions of the MMU is to ensure that code and data in any particular level are accessed only by code or processes that have the right permissions. The four execution levels are defined as:

- Kernel (level 0) The most privileged level; it contains the operating system's most privileged services (e.g., device drivers and interrupt handlers).
- Executive (level 1) This level is provided for greater flexibility in the operating system design.
- Supervisor (level 2) Common library routines can operate at this level and be safe from corruption by the level 3 activities.
- User (level 3) The least privileged level; most user programs can run in this level.

Table 9-1 lists the powerful WE 32100 Microprocessor instructions provided for operating systems. These instructions have two levels of hierarchy: *privileged* and *nonprivileged*. Privileged instructions may be executed only if the processor is in kernel level and they are used to perform process switches, to enable or disable the MMU, or to suspend fetching of instructions. Nonprivileged instructions do not depend on the execution level (i.e., they can be executed at any level) and are used to switch between execution levels (in ways restricted by the operating system) or to convert a virtual address to a physical address.

The processor automatically executes the appropriate *microsequence* (a built-in sequence of actions), when an interrupt is requested or an exception occurs. These microsequences and many operating system instructions can call functions (also microsequences) that do the context switching (changing the hardware context for the new process to be executed). This feature takes the requirements of context switching out of the operating system, allowing for quicker and more efficient operating system design and execution. The operating system instructions and microsequences are described in the *WE* 32100 Microprocessor Information Manual.

| Table 9-1. Operating System Instructions |                    |               |                                                                                                                                                                                                                      |  |  |
|------------------------------------------|--------------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Privileged Instructions                  |                    |               |                                                                                                                                                                                                                      |  |  |
| Instruction                              | Assembly<br>Syntax | Hex<br>Opcode | Description                                                                                                                                                                                                          |  |  |
| Enable virtual<br>pin and jump           | ENBVJMP            | 300D          | Enables the MMU to translate addresses.<br>The virtual address of the first instruction to<br>be executed after the MMU is enabled must<br>be stored in register <b>r0</b> before this instruction<br>is executed.   |  |  |
| Disable virtual<br>pin and jump          | DISVJMP            | 3013          | Disables the MMU from translating<br>addresses. The physical address of the first<br>instruction to be executed after the MMU is<br>disabled must be stored in register $r0$ before<br>this instruction is executed. |  |  |
| Call Process                             | CALLPS             | 30AC          | Performs an explicit process switch.                                                                                                                                                                                 |  |  |
| Return to process                        | RETPS              | 30C8          | Restores a process from an interrupted state.                                                                                                                                                                        |  |  |
| Wait for interrupt                       | WAIT               | 2F            | Stops the CPU from fetching instructions.<br>Fetching resumes after an interrupt is<br>encountered.                                                                                                                  |  |  |
| Interrupt<br>Acknowledge                 | INTACK             | 302F          | Stores interrupt id in r0.                                                                                                                                                                                           |  |  |
| Move translated<br>word                  | MOVTRW src,dst     | 0C            | The MMU converts the virtual address<br>specified by <i>src</i> to a physical address. The<br>result is stored in <i>dst</i> . Can be used to obtain<br>physical address to send to an I/O device.                   |  |  |
| Table 9-1. Operating System Instructions (Continued) |                            |               |                                                                                                                                                                                                           |  |  |
|------------------------------------------------------|----------------------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                                                      | Nonprivileged Instructions |               |                                                                                                                                                                                                           |  |  |
| Instruction                                          | Assembly<br>Syntax         | Hex<br>Opcode | Description                                                                                                                                                                                               |  |  |
| Gate                                                 | GATE                       | 3061          | Mechanism used to transfer control between different execution levels.                                                                                                                                    |  |  |
| Return from<br>Gate                                  | RETG                       | 3045          | Returns control to the function which called<br>the gate. Linear ordering of execution levels<br>is enforced by RETG (i.e., new execution<br>level may not be more privileged than the<br>current level). |  |  |

Other features of the microprocessor's architecture that are provided for operating system design are summarized as follows:

- The microprocessor supports different levels of execution privilege and enforces linear ordering of these levels only on a return-from-gate (RETG) instruction.
- The microprocessor provides flexibility in transferring execution control between privilege levels. Control is transferred through the gate mechanism.
- A scheduler may explicitly switch processes (CALLPS or RETPS instructions), but part of the interrupt structure and certain exception conditions involve implicit switching of processes. This provides some of the interrupt structure and some of the exception handler advantages of a process switch.
- The processor supports a layered exception-handling structure that uses different mechanisms (process switching or gate mechanism), depending on the severity of the exception.
- The processor supports *full* and *quick* interrupt handlers that use different mechanisms (process switching or gate mechanism). A full interrupt is handled as an implicit process switch, while a quick interrupt is handled as an implicit gate.
- Address space of each process may include the space that contains the operating system; i.e., the user may pass and address arguments across system calls efficiently, but need not switch memory map information across such calls.
- The processor supports memory management, permitting users to believe the system has 4 Gbytes of memory. However, the operating system must provide the information required by a memory management unit (MMU) to translate virtual addresses (i.e., memory descriptors) or disable the MMU for physical addressing. Systems without an MMU use only physical addressing.

#### 9.1.1 Memory Management Considerations for Virtual Memory Systems

A memory management unit (MMU) is required for virtual memory (storage) systems. The primary function of an MMU is to translate virtual address into physical addresses and implement the protection of each process' data. The features that support a virtual memory operating system are:

• Support of contiguous segments and paged segments. Segments, or blocks of memory, are defined by memory descriptors. The WE 32101 Memory Management Unit uses segment descriptors to define contiguous segments (i.e., a block of memory defined up to 128 Kbytes in length) and segment and page descriptors to define paged segments (i.e., a block of memory defined to contain up to sixty-four 2 Kbyte pages).

- Present bits to indicate whether or not a segment is currently in main memory.
- *Referenced* and *modified* bits to aid implementation of a least recently used (LRU) algorithm in the operating system.
- An *indirection* feature that allows segments to be given different access permissions (e.g., read or write), yet still be shared by different routines running at the same execution level.
- Access fields contained in segment descriptors are used to provide protection so that segments are accessed in the appropriate way by the appropriate execution level. An access exception is generated if access is disallowed.
- An *object-trap* feature provides a mechanism where I/O devices or external processors appear as normal segments from the user-software point of view.
- Segment marking as cacheable or not cacheable using a cacheable bit. This can be used to aid the use of an external data cache in the system main memory.
- A unique exception (page-write) that can be issued on any attempt to write a given page. on the

Detailed information or Operating System interface can be found in the WE 32100 Microprocessor Information Manual.

CALLS THESE "REGIONS"

A: SVR3

9-4

A

Chapter 10 Floating Point Support

# CHAPTER 10. FLOATING POINT SUPPORT

# CONTENTS

| 10. FLOATING POINT SUPPORT 1                                      | 10-1 |
|-------------------------------------------------------------------|------|
| 10.1 WE 32106 MATH ACCELERATION UNIT ASSEMBLY                     |      |
| LANGUAGE INSTRUCTION SET                                          | 10-  |
| 10.1.1 Programmer's Overview of WE 32106 Math Acceleration Unit 1 | 10-  |
| MAU Register Support 1                                            | 10-1 |
| Conditional Jump Instructions                                     | 10-2 |
| MAU Control Bits 1                                                | 10-2 |
| Immediate Operands 1                                              | 10-: |
| 10.1.2 Data Types                                                 | 10   |
| 10.1.3 MIS Instruction Listings                                   | 10-  |
| Notation                                                          | 10-  |
| MIS Instruction Set Descriptions 1                                | 10-  |
| MIS Instructions Summary by Function 1                            | 10-: |
| MIS Instructions Summary by Mnemonic                              | 10-  |
| 10.2 FLOATING POINT EMULATION LIBRARY                             | 10-  |
| 10.2.1 Assembly Language Support                                  | 10-0 |
| 10.2.2 Data Type                                                  | 10-0 |
| 10.2.3 Floating Point Environment and Exception Handling          | 10-0 |
| 10.2.4 Library Listings                                           | 10-0 |
| Notation                                                          | 10-0 |
| FPE Function Call Descriptions 1                                  | 10-0 |
| FPE Function Call Summary By Function                             | 10-  |
| FPE Function Call Summary By Mnemonic                             | 10-  |

# CHAPTER 10. FLOATING POINT SUPPORT

# CONTENTS

| 10. FLOATING POINT SUPPORT                                      | 10-1  |
|-----------------------------------------------------------------|-------|
| 10.1 WE 32106 MATH ACCELERATION UNIT ASSEMBLY                   |       |
| LANGUAGE INSTRUCTION SET                                        | 10-1  |
| 10.1.1 Programmer's Overview of WE 32106 Math Acceleration Unit | 10-1  |
| MAU Register Support                                            | 10-1  |
| Conditional Jump Instructions                                   | 10-2  |
| MAU Control Bits                                                | 10-2  |
| Immediate Operands                                              | 10-3  |
| 10.1.2 Data Types                                               | 10-3  |
| 10.1.3 MIS Instruction Listings                                 | 10-5  |
| Notation                                                        | 10-5  |
| MIS Instruction Set Descriptions                                | 10-7  |
| MIS Instructions Summary by Function                            | 10-56 |
| MIS Instructions Summary by Mnemonic                            | 10-60 |
| 10.2 FLOATING POINT EMULATION LIBRARY                           | 10-63 |
| 10.2.1 Assembly Language Support                                | 10-63 |
| 10.2.2 Data Type                                                | 10-63 |
| 10.2.3 Floating Point Environment and Exception Handling        | 10-63 |
| 10.2.4 Library Listings                                         | 10-67 |
| Notation                                                        | 10-67 |
| FPE Function Call Descriptions                                  | 10-67 |
| FPE Function Call Summary By Function                           | 10-83 |
| FPE Function Call Summary By Mnemonic                           | 10-84 |

#### **10. FLOATING POINT SUPPORT**

Support for floating point operations is provided by either the WE 32106 Math Acceleration Unit (MAU) Assembly Language Instruction Set (MIS) or the Floating Point Emulation (FPE) Library. Programmers using 3B2/3B6/and 3B15 Computers that contain an MAU can use either the MIS or the FPE Library (to allow programs to be compatible with all 3B2/3B5/and 3B15 Computers) when coding in assembly language, while programmers using computers which do not contain an MAU must use the FPE library. 10.1 describes the MIS and 10.2 describes the FPE library.

# 10.1 WE 32106 MATH ACCELERATION UNIT ASSEMBLY LANGUAGE INSTRUCTION SET

The following describes the WE 32106 Math Acceleration Unit assembly language instruction set that can be used with the 3B2/3B5/3B15 Computers. The MIS instruction set is an addition to the WE 32100 Microprocessor assembly language instruction set that frees the programmer from the task of generating the proper sequence of coprocessor instructions for the MAU to perform floating point operations. This section also discusses the data types used by the MIS instructions and contains an alphabetical one-page description of each MIS instruction.

#### 10.1.1 Programmer's Overview Of WE 32106 Math Acceleration Unit (MAU)

This section describes the programming conventions used to support the MAU. Included in the discussion are: register usage, the immediate addressing mode notation, solutions for the problems of conditional jumps, and mixed mode arithmetic. Floating point decimal data type, which is required by the IEEE standard draft 10, is not supported by the assembler but library functions are provided to support this data type. All of the data types which are supported by the MAU (i.e., all the floating point types, words, and decimal integer) are accessible through all of the addressing modes described in 5. Addressing Modes, except the immediate (discussed later in this section).

For a more detailed description of the MAU refer to the WE 32106 Math Acceleration Unit Data Sheet.

#### **MAU Register Support**

The MAU registers can contain only floating point data types (i.e., single, double, and double extended formats). Three out of the four MAU operand registers (numbers F0, F1, and F2) are available to the programmer. The fourth operand register (F3) is reserved for the assembler to perform substitutions for operations that use two source operands in memory. In these cases, the assembler generates two coprocessor operations, one to store one of the operands in register F3 and the second to execute the operation. The assembler does not restrict the use of F3; but since this register is reserved, the programmer is

responsible for the consequences. Each MAU operand register has three names, one for each data type format:

- %s0, %s1, %s2, and %s3 for single precision
- %d0, %d1, %d2, and %d3 for double precision
- %x0, %x1, %x2, and %x3 for double extended precision.

The 0, 1, 2, and 3 correspond to the MAU operand registers F0, F1, F2, and F3, respectively.

The role of this notation is to indicate to the assembler what precision to round the register in case it is a destination and to supply *type* information in case it is a source operand. The assembler checks if the destination is narrower than the sources. If it is narrower, which is a violation of the IEEE standard draft 10, the instruction is replaced by an operation with the correct destination followed by conversion to the narrower destination as required by the IEEE standard. The fourth register is used for the intermediate result in this substitution. A default name for each register (% f0, % f1, % f2, and % f3) is also provided. The purpose of this notation is to eliminate the substitution. If it is used as a source operand, this operand does not participate in data type matching. If it is used as a destination, no substitution is done. The type for the rounding in this case is taken from the MIS instruction's opcode.

#### **Conditional Jump Instructions**

The assembler supports a set of floating point conditional jump instructions that, together with the compare instructions, supplies the predicates required by the IEEE standard draft 10. The assembler uses this set of jumps, based on the Auxiliary Status Register (ASR) flags in the MAU instead of the Processor Status Word (PSW) flags. For this purpose, the assembler reads the ASR into a word which is allocated on the stack. Although stack manipulations alter the PSW flags, corrupting the PSW flags does not affect the next floating point jump since this set uses only the ASR. The option -G used in the assembler command line substitutes the MIS jump instructions with the set of jump instructions which jump according to the contents of the PSW. This mode of operation of the assembler is referred to as PSW mode. If this option is taken, performance is improved and size is decreased since the access of the ASR is eliminated. However, the unordered condition is not detectable since the unordered bit of the ASR is not available in the PSW. Programmers who are willing to gain this performance, and relax the IEEE standard draft 10 requirements for jumps, can use this option.

#### **MAU Control Bits**

The MAU contains control bits in the ASR (i.e., rounding control, trap masks, and context switch control). No special instructions are implemented for these bits and the bits are controlled by reading from the ASR and writing to it. The programmer, however, must be careful to change only the desired bits in the ASR.

#### Immediate Operands

Although immediate operands are not supported by the MAU/CPU. the assembler provides the immediate notation for all of the supported data types. This is done by storing these operands as constants in the data section at assembly time. This static storage allocation does not involve any penalty in execution speed.

#### 10.1.2 Data Types

The floating point data types supported by the assembler are illustrated on Figure 10-1 and are defined as:

single

A 32-bit quantity that may appear at any address in memory divisible by four. Its bits are numbered from right to left starting with 0, the least significant bit (LSB), and ending with 31, the most significant bit (MSB). Bit 31 is the sign bit (s), bits 23 through 30 represent the exponential component (e) biased by 127, and bits 0 through 22 represent the fractional component (f). The value (v) of a single precision floating point number is calculated as:

- If 0 < e < 255 then  $v = (-1)^{**s} \times 2^{**}(e-127) \times 1.f$ a.
- If e = 0 and  $f \neq 0$  then  $v = (-1)^{**s} \times 2^{**}(e-126) \times 0.f$ h
- If e = 0 and f = 0 then v = 0c.
- If e = 255 and f = 0 then  $v = (-1)^{**s} \times infinity$ d.
- If e = 255 and  $f \neq 0$  then v = NaNe.

Note that NaN means "Not-a-Number" (see 10.2.3).

double

A 64-bit quantity that may appear at any address in memory divisible by four. Its bits are numbered from right to left starting with 0, the LSB, and ending with 63, the MSB. Bit 63 is the sign bit (s), bits 52 through 62 represent the exponential component (e) biased by 1023, and bits 0 through 51 represent the fractional component (f). The value (v) of a double precision floating point number is calculated as:

- If 0 < e < 2047 then  $v = (-1)^{**s} \times 2^{**}(e-1023) \times 1.f$ a.
- b. If e = 0 and  $f \neq 0$  then  $v = (-1)^{**s} \times 2^{**}(e-1022) \times 0.f$
- If e = 0 and f = 0 then v = 0c.
- d. If e = 2047 and f = 0 then  $v = (-1)^{**s} \times infinity$
- e. If e = 2047 and  $f \neq 0$  then v = NaN

double extended An 96-bit quantity that may appear at any address in memory divisible by four. Its bits are numbered from right to left starting with 0, the LSB, and ending with 95, the MSB. Bit 80 through 95 are ignored when read, and zeros are written during a write. Bit 79 is the sign bit (s), bits 64 through 78 represent the exponential component (e) biased by 16383,

bit 63 represents the explicit bit (j), and bits 0 through 62 represent the fractional component (f). The value (v) of a double precision floating point number is calculated as:

- a. If 0 < e < 32767 then  $v = (-1)^{**s} \times 2^{**}(e-16383) \times j.f$
- b. If e = 0 and  $f \neq 0$  then  $v = (-1)^{**s} \times 2^{**}(e-16382) \times j.f$
- c. If e = 0 and f = 0 then v = 0
- d. If e = 32767 and f = 0 then  $v = (-1)^{**s} \times infinity$
- e. If e = 32767 and  $f \neq 0$  then v = NaN

| Bit   | 31   | 30   | 23    | 22   | 0    |
|-------|------|------|-------|------|------|
| Field | Sign | Expo | onent | Frac | tion |



| Bit   | 63   | 62   | 52    | 51   | 0    |
|-------|------|------|-------|------|------|
| Field | Sign | Expo | onent | Frac | tion |

**B.** Double Data

| Bit   | 95  | 80   | 79   | 78   | 64    | 63 | 62   | 0    |
|-------|-----|------|------|------|-------|----|------|------|
| Field | Unı | ised | Sign | Expo | onent | J  | Frac | tion |

C. Double Extended Data

Figure 10-1. Bit Order of Data

#### **10.1.3 MIS Instruction Listings**

The following presents descriptions of each floating point instruction. The descriptions are in alphabetical order and any instruction that operates on more than one type of operand, single, double, or double extended, are listed on the same page (for quick reference to the instructions by function or mnemonic see MIS Instructions Summary By Function and MIS Instructions Summary By Mnemonic in this section). The notation used in the listings is described following.

#### Notation

Each instruction description contains four parts: format, operation, description, and condition indicators.

**Format.** Presents the assembly language syntax for the instruction, including any required spacing and punctuation. The user-specified elements appear in *italics*. All operands must appear in the order shown. If an instruction has single, double, and double extended forms, all three forms are presented.

The syntax uses the *dst* and *src* symbols to denote operands that may be written in the address modes described in Chapter 3 of the *WE* 32100 Microprocessor Information Manual.

**Operation**. Describes the operation performed, generally, using C language syntax and the operators and symbols shown in Table 10-1.

**Description**. Describes the operation performed. Also, any additional explanation is included where necessary.

**Result Types.** Identifies the type of result that each can have upon completion of the performed operation. Table 10-2 lists the result types and their associated meanings.

#### FLOATING POINT SUPPORT Notation

| Table 10-1. Assembly Language Operators and Symbols |                                                                       |  |  |
|-----------------------------------------------------|-----------------------------------------------------------------------|--|--|
| Symbol                                              | Description                                                           |  |  |
| x                                                   | Absolute value of x                                                   |  |  |
| -x                                                  | Negate x; form two's complement of x                                  |  |  |
| x+y                                                 | Add y to x                                                            |  |  |
| х—у                                                 | Subtract y from x                                                     |  |  |
| x*y                                                 | Multiply x by y                                                       |  |  |
| x/y                                                 | Divide y into x                                                       |  |  |
| x%y                                                 | Modulo x and y (remainder of x/y)                                     |  |  |
| x < y                                               | x less than y                                                         |  |  |
| x <=y                                               | x less than or equal to y                                             |  |  |
| x>y                                                 | x greater than y                                                      |  |  |
| x>=y                                                | x greater than or equal to y                                          |  |  |
| x==y                                                | Equality; x equal to y                                                |  |  |
| x!=y                                                | x not equal to y                                                      |  |  |
| _                                                   | Assigns the value on the right to the location identified on the left |  |  |
| address                                             | Address of memory location                                            |  |  |
| dst                                                 | Destination operand                                                   |  |  |
| src                                                 | Source operand                                                        |  |  |
| COMPARE(x,y)                                        | Compare the contents of x and y                                       |  |  |
| CONVERT(x)                                          | Convert data type of x operation                                      |  |  |
| ROUND(x)                                            | Rounding of x operation                                               |  |  |
| PC                                                  | Program counter                                                       |  |  |
| SQR(x)                                              | Find square root of x operation                                       |  |  |

| Table 10-2. Floating Point Result Types |                                                                                                                                                              |  |  |
|-----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Result Types                            | Description                                                                                                                                                  |  |  |
| FLOATING-POSITIVE-ZERO                  | The result of an operation is +0.                                                                                                                            |  |  |
| FLOATING-NEGATIVE-ZERO                  | The result of an operation is $-0$ .                                                                                                                         |  |  |
| FLOATING-POSITIVE-NONZERO               | The result of an operation has a positive sign bit and is not zero.                                                                                          |  |  |
| FLOATING-NEGATIVE-NONZERO               | The result of an operation has a negative sign bit<br>and is not zero.                                                                                       |  |  |
| FLOATING-EQUAL                          | In a compare operation the two operands are equal.                                                                                                           |  |  |
| FLOATING-LESS                           | In a compare operation src1 is less than src2.                                                                                                               |  |  |
| FLOATING-GREATER                        | In a compare operation src1 is greater than src2.                                                                                                            |  |  |
| FLOATING-UNORDERED                      | In a compare operation <i>src1</i> or <i>src2</i> is a symbolic<br>entity encoded in floating-point format and <i>src1</i><br>and <i>src2</i> are not equal. |  |  |
| NEGATIVE                                | The result of an operation has a negative sign bit<br>and is not a floating-point value.                                                                     |  |  |
| POSITIVE                                | The result of an operation has a positive sign bit<br>and is not a floating-point value.                                                                     |  |  |
| ZERO                                    | The result of an operation is zero and is not a floating-point value.                                                                                        |  |  |

#### **MIS Instruction Set Descriptions**

The instruction set is described in detail on the following pages.

,

#### mfabss1 mfabsd1 mfabsx1

mfabss1 mfabsd1 mfabsx1

#### Floating Absolute Value One Operand

| Format      | mfabss1 dst<br>mfabsd1 dst   | Single<br>Double                                                                                             |
|-------------|------------------------------|--------------------------------------------------------------------------------------------------------------|
|             | mfasbx1 dst                  | Double extended                                                                                              |
| Operation   | dst =  dst                   |                                                                                                              |
| Description | The absolute result is copie | value of the contents of $dst$ is taken and the floating point d back into the location specified by $dst$ . |
| Result      | FLOATING-                    | POSITIVE-ZERO                                                                                                |
| r shee      | FLUAIING-                    | rushtive-indinzeru                                                                                           |

### mfabss2 mfabsd2 mfabsx2

mfabss2 mfabsd2 mfabsx2

#### Floating Absolute Value Two Operands

| Format      | mfabss2 src,dst Single<br>mfabsd2 src,dst Double<br>mfabsx2 src,dst Double extended                |                                                  |
|-------------|----------------------------------------------------------------------------------------------------|--------------------------------------------------|
| Operation   | dst =  src                                                                                         |                                                  |
| Description | The absolute value of the contents of <i>src</i> is result is copied back into the location specif | taken and the floating point ied by <i>dst</i> . |
| Result      | FLOATING-POSITIVE-ZERO                                                                             |                                                  |
| Types       | FLOATING-POSITIVE-NONZERO                                                                          |                                                  |

,

#### mfadds2 mfaddd2 mfaddx2

mfadds2 mfaddd2 mfaddx2

#### Floating Add Two Operands

| Format      | mfadds2 src,dst                            | Single                                                                                                |  |  |
|-------------|--------------------------------------------|-------------------------------------------------------------------------------------------------------|--|--|
|             | mfaddx2 src,dst                            | Double extended                                                                                       |  |  |
| Operation   | dst = dst + src                            |                                                                                                       |  |  |
| Description | The contents of survey result is copied by | rc are added to the contents of $dst$ . The floating point ack into the location specified by $dst$ . |  |  |
| Result      | FLOATING-POS                               | SITIVE-ZERO                                                                                           |  |  |
| Types       | FLOATING-NEGATIVE-ZERO                     |                                                                                                       |  |  |
| 2 4         | FLOATING-POSITIVE-NONZERO                  |                                                                                                       |  |  |
|             | FLOATING-NEGATIVE-NONZERO                  |                                                                                                       |  |  |

# Floating Add Three Operands

| Format      | mfadds3 <i>src1,src2,dst</i><br>mfaddd3 <i>src1,src2,dst</i> | Single<br>Double                                                                      |  |  |  |
|-------------|--------------------------------------------------------------|---------------------------------------------------------------------------------------|--|--|--|
|             | mfaddx3 src1,src2,dst                                        | Double extended                                                                       |  |  |  |
| Operation   | dst = src1 + src2                                            |                                                                                       |  |  |  |
| Description | The contents of <i>src2</i> arpoint result is copied in      | e added to the contents of $srcl$ . The floating to the location specified by $dst$ . |  |  |  |
| Result      | FLOATING-POSITIV                                             | E-ZERO                                                                                |  |  |  |
| Types       | FLOATING-NEGATI                                              | VE-ZERO                                                                               |  |  |  |
|             | FLOATING-POSITIVE-NONZERO                                    |                                                                                       |  |  |  |
|             | FLOATING-NEGATI                                              | VE-NONZERO                                                                            |  |  |  |
|             |                                                              |                                                                                       |  |  |  |





**Floating Compare** 

Formatmfcmps src1,src2Single<br/>mfcmpd src1,src2Double<br/>mfcmpx src1,src2Double<br/>Double extendedOperationCOMPARE(src1,src2)DescriptionThe contents of src1 and src2 are compared

The contents of src1 and src2 are compared and appropriate condition indicators are set. This instruction is used prior to a branch or jump instruction.

Result Types FLOATING-EQUAL FLOATING-LESS FLOATING-GREATER FLOATING-UNORDERED

# mfcmpts mfcmptd mfcmptx

# mfcmpts mfcmptd mfcmptx

#### Floating Compare With Trap Operation

| Format      | mfcmpts src1,src2Singlemfcmptd src1,src2Doublemfcmptx src1,src2Double extended                                                                                         |  |  |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Operation   | COMPARE(src1,src2)                                                                                                                                                     |  |  |
| Description | The contents of <i>src1</i> and <i>src2</i> are compared and appropriate condition indicators are set. This instruction is used prior to a branch or jump instruction. |  |  |
|             | When an unordered condition is detected, and the invalid operation exception is enabled, an invalid operation trap occurs.                                             |  |  |
| Result      | FLOATING-EQUAL                                                                                                                                                         |  |  |
| Types       | FLOATING-LESS                                                                                                                                                          |  |  |
|             | FLOATING-GREATER                                                                                                                                                       |  |  |
|             | FLOATING-UNORDERED                                                                                                                                                     |  |  |

mfdivs2 mfdivd2 mfdivx2

# Floating Divide Two Operands

| nfdivs2 <i>src,dst</i><br>mfdivd2 <i>src,dst</i><br>mfdivx2 <i>src,dst</i>                                                                   | Single<br>Double<br>Double extended                                                                                                                                                            |  |
|----------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| dst = dst / src                                                                                                                              |                                                                                                                                                                                                |  |
| The contents of $dst$ are divided by the contents of $src$ . The floating point result is copied back into the location specified by $dst$ . |                                                                                                                                                                                                |  |
| FLOATING-POSITIVE-ZERO                                                                                                                       |                                                                                                                                                                                                |  |
| FLOATING-NEGATIVE-ZERO                                                                                                                       |                                                                                                                                                                                                |  |
| FLOATING-POSITIVE-NONZERO                                                                                                                    |                                                                                                                                                                                                |  |
| FLOATING-NE                                                                                                                                  | GATIVE-NONZERO                                                                                                                                                                                 |  |
|                                                                                                                                              | nfdivs2 <i>src,dst</i><br>mfdivd2 <i>src,dst</i><br>mfdivx2 <i>src,dst</i><br>dst = dst / src<br>The contents of <i>d</i><br>point result is cop<br>FLOATING-POS<br>FLOATING-NE<br>FLOATING-NE |  |

Ì

#### mfdivs3 mfdivd3 mfdivx3

mfdivs3 mfdivd3 mfdivx3

.

.

# Floating Divide Three Operands

| Format      | mfdivs3 src1, src2, dst                                                                                                                   | Single          |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
|             | mfdivd3 <i>src1,src2,dst</i>                                                                                                              | Double          |
|             | mfdivx3 src1,src2,dst                                                                                                                     | Double extended |
| Operation   | dst = src2 / src1                                                                                                                         |                 |
| Description | The contents of $src2$ are divided by the contents of $src1$ . The floating point result is copied into the location specified by $dst$ . |                 |
| Result      | FLOATING-POSITIVE-ZERO                                                                                                                    |                 |
| Types       | FLOATING-NEGATIVE-ZERO                                                                                                                    |                 |
|             | FLOATING-POSITIVE-NONZERO                                                                                                                 |                 |
|             | FLOATING-NEGAT                                                                                                                            | IVE-NONZERO     |
|             |                                                                                                                                           |                 |

### mfmuls2 mfmuld2 mfmulx2

mfmuls2 mfmuld2 mfmulx2

# Floating Multiply Two Operands

| Format          | mfmuls2 src,dstSinglemfmuld2 src,dstDoublemfmulx2 src,dstDouble extended                                                                        |  |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Operation       | dst = dst * src                                                                                                                                 |  |
| Description     | The contents of $dst$ are multiplied by the contents of $src$ . The floating point result is copied back into the location specified by $dst$ . |  |
| Result<br>Types | FLOATING-POSITIVE-ZERO<br>FLOATING-NEGATIVE-ZERO                                                                                                |  |
| <b>у</b> д "    | FLOATING-POSITIVE-NONZERO<br>FLOATING-NEGATIVE-NONZERO                                                                                          |  |

mfmuls3 mfmuld3 mfmulx3

#### Floating Multiply Three Operands

| Format          | mfmuls3 src1,src2,dst<br>mfmuld3 src1,src2,dst<br>mfmulx3 src1,src2,dst                                                                      | Single<br>Double<br>Double extended |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|
| Operation       | dst = src1 * src2                                                                                                                            |                                     |
| Description     | The contents of $src1$ are multiplied by the contents of $src2$ . The floating point result is copied into the location specified by $dst$ . |                                     |
| Result<br>Types | FLOATING-POSITIVE-ZERO<br>FLOATING-NEGATIVE-ZERO<br>FLOATING-POSITIVE-NONZERO<br>FLOATING-NEGATIVE-NONZERO                                   |                                     |
|                 |                                                                                                                                              |                                     |

# mfnegs1 mfnegd1 mfnegx1

10-18

10

mfnegs1 mfnegd1 mfnegx1

# Floating Negate One Operand

| Format      | mfnegs1 dst Single                                                                                                                               |  |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------|--|
|             | mfnegd1 dst Double                                                                                                                               |  |
|             | mfnegx1 dst Double extended                                                                                                                      |  |
| Operation   | dst = -dst                                                                                                                                       |  |
| Description | The two's complement value of the contents of $dst$ is taken and the floating point result is copied back into the location specified by $dst$ . |  |
| Result      | FLOATING-POSITIVE-ZERO                                                                                                                           |  |
| Types       | FLOATING-NEGATIVE-ZERO                                                                                                                           |  |
|             | FLOATING-POSITIVE-NONZERO                                                                                                                        |  |
|             | FLOATING-NEGATIVE-NONZERO                                                                                                                        |  |
|             |                                                                                                                                                  |  |

# mfnegs2 mfnegd2 mfnegx2

mfnegs2 mfnegd2 mfnegx2

# Floating Negate Two Operands

.

| Format      | mfnegs2 src,dst<br>mfnegd2 src,dst      | Single<br>Double                                                                                      |
|-------------|-----------------------------------------|-------------------------------------------------------------------------------------------------------|
|             | mfnegx2 src,dst                         | Double extended                                                                                       |
| Operation   | dst = -src                              |                                                                                                       |
| Description | The negated valu<br>result is copied by | e of the contents of $src$ is taken and the floating point ack into the location specified by $dst$ . |
| Result      | FLOATING-PO                             | SITIVE-ZERO                                                                                           |
| Types       | FLOATING-NE                             | GATIVE-ZERO                                                                                           |
|             | FLOATING-PO                             | SITIVE-NONZERO                                                                                        |
|             | FLOATING-NE                             | GATIVE-NONZERO                                                                                        |

#### mfrems2 mfremd2 mfremx2

# Floating Remainder Divide Two Operands

| Format          | mfrems2 src,dstSinglemfremd2 src,dstDoublemfremx2 src,dstDouble extended                                                                               |  |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Operation       | dst = dst % src                                                                                                                                        |  |
| Description     | The contents of $dst$ are divided by the contents of $src$ . The floating point remainder result is copied back into the location specified by $dst$ . |  |
| Result<br>Types | FLOATING-POSITIVE-ZERO<br>FLOATING-NEGATIVE-ZERO<br>FLOATING-POSITIVE-NONZERO<br>FLOATING-NEGATIVE-NONZERO                                             |  |

mfrems3 mfremd3 mfremx3

#### Floating Remainder Divide Three Operands

| mfrems3 src1,src2,dst<br>mfremd3 src1,src2,dst<br>mfremx3 src1,src2,dst                                                                             | Single<br>Double<br>Double extended                                                                                                                                                                                  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| dst = src2 % src1                                                                                                                                   |                                                                                                                                                                                                                      |  |
| The contents of $src2$ are divided by the contents of $src1$ . The floating point remainder result is copied into the location specified by $dst$ . |                                                                                                                                                                                                                      |  |
| FLOATING-POSITIVE-ZERO                                                                                                                              |                                                                                                                                                                                                                      |  |
| FLOATING-NEGATIVE-ZERO                                                                                                                              |                                                                                                                                                                                                                      |  |
| FLOATING-POSITIVE-NONZERO                                                                                                                           |                                                                                                                                                                                                                      |  |
| FLOATING-NEGATIV                                                                                                                                    | /E-NONZERO                                                                                                                                                                                                           |  |
|                                                                                                                                                     | mfrems3 src1,src2,dst<br>mfremd3 src1,src2,dst<br>mfremx3 src1,src2,dst<br>dst = src2 % src1<br>The contents of src2 are<br>point remainder result is<br>FLOATING-POSITIVE<br>FLOATING-NEGATIVE<br>FLOATING-NEGATIVE |  |

### mfrnds1 mfrndd1 mfrndx1

.

#### Floating Round to Integral Value One Operand

| Format          | mfrnds1 dst Single<br>mfrndd1 dst Double<br>mfrndx1 dst Double extended                                                                            |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation       | dst = ROUND(dst)                                                                                                                                   |
| Description     | The contents of $dst$ are rounded to an integral value in floating-point format and the result is copied back into the location specified by $dst$ |
| Result<br>Types | FLOATING-POSITIVE-ZERO<br>FLOATING-NEGATIVE-ZERO<br>FLOATING-POSITIVE-NONZERO<br>FLOATING-NEGATIVE-NONZERO                                         |

#### mfrnds2 mfrndd2 mfrndx2

#### mfrnds2 mfrndd2 mfrndx2

#### Floating Round to Integral Value Two Operands

| Format      | mfrnds2 <i>src,dst</i>                                                                                                      | Single          |  |
|-------------|-----------------------------------------------------------------------------------------------------------------------------|-----------------|--|
|             | mfrndx2 src,dst                                                                                                             | Double extended |  |
| Operation   | dst = ROUND(s)                                                                                                              | src)            |  |
| Description | The contents of $src$ are rounded to an integral value and the result is copied back into the location specified by $dst$ . |                 |  |
| Result      | FLOATING-POSITIVE-ZERO                                                                                                      |                 |  |
| Types       | FLOATING-NEGATIVE-ZERO                                                                                                      |                 |  |
|             | FLOATING-POSITIVE-NONZERO                                                                                                   |                 |  |
|             | FLOATING-NEGATIVE-NONZERO                                                                                                   |                 |  |

mfsqrs1 mfsqrd1 mfsqrx1

1

#### Floating Square Root One Operand

| Format      | mfsqrs1 dst Single<br>mfsqrd1 dst Double<br>mfsqrx1 dst Double extended                                                               |  |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------|--|
| Operation   | dst = SQR(dst)                                                                                                                        |  |
| Description | The square root of the contents of $dst$ is taken and the floating point result is copied back into the location specified by $dst$ . |  |
| Result      | FLOATING-POSITIVE-ZERO                                                                                                                |  |
| Types       | FLOATING-NEGATIVE-ZERO                                                                                                                |  |
|             | FLOATING-POSITIVE-NONZERO                                                                                                             |  |
|             | FLOATING-NEGATIVE-NONZERO                                                                                                             |  |

# mfsqrs2 mfsqrd2 mfsqrx2

# mfsqrs2 mfsqrd2 mfsqrx2

# Floating Square Root Two Operands

| Format      | mfsqrs2 <i>src,dst</i><br>mfsqrd2 <i>src,dst</i><br>mfsqrx2 <i>src,dst</i>                                                       | Single<br>Double<br>Double extended |
|-------------|----------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|
| Operation   | dst = SQR(src)                                                                                                                   |                                     |
| Description | The square root of the contents of $src$ is taken and the floating point result is copied into the location specified by $dst$ . |                                     |
| Result      | FLOATING-POSITIVE-ZERO                                                                                                           |                                     |
| Types       | FLOATING-NEGATIVE-ZERO                                                                                                           |                                     |
|             | FLOATING-NE                                                                                                                      | GATIVE-NONZERO                      |

#### mfsubs2 mfsubd2 mfsubx2

mfsubs2 mfsubd2 mfsubx2

#### Floating Subtract Two Operands

| Format      | mfsubs2 <i>src,dst</i><br>mfsubd2 <i>src,dst</i>                                                                                                                 | Single<br>Double |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
|             | mfsubx2 src,dst                                                                                                                                                  | Double extended  |
| Operation   | dst = dst - src                                                                                                                                                  |                  |
| Description | The contents of <i>src</i> are subtracted from the contents of <i>dst</i> . The floating point result is copied back into the location specified by <i>dst</i> . |                  |
| Result      | FLOATING-POSITIVE-ZERO                                                                                                                                           |                  |
| Types       | FLOATING-NEGATIVE-ZERO                                                                                                                                           |                  |
|             | FLOATING-POSITIVE-NONZERO                                                                                                                                        |                  |
|             | FLOATING-NE                                                                                                                                                      | GATIVE-NONZERO   |

١

#### mfsubs3 mfsubd3 mfsubx3

mfsubs3 mfsubd3 mfsubx3

#### Floating Subtract Three Operands

| Format      | mfsubs3 src1, src2, dst Single<br>mfsubd3 src1, src2, dst Double<br>mfsubx3 src1, src2, dst Double extended                                    |  |  |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Operation   | dst = src2 - src1                                                                                                                              |  |  |
| Description | The contents of $src1$ are subtracted from the contents of $src2$ . The floating point result is copied into the location specified by $dst$ . |  |  |
| Result      | FLOATING-POSITIVE-ZERO                                                                                                                         |  |  |
| Types       | FLOATING-NEGATIVE-ZERO                                                                                                                         |  |  |
|             | FLOATING-POSITIVE-NONZERO                                                                                                                      |  |  |
|             | FLOATING-NEGATIVE-NONZERO                                                                                                                      |  |  |

#### mjfcc

#### Floating Conditional Jumps

Format

#### **Arithmetic Jump Operations**

mjfneg dst Negative mjfnz dst Not Zero mjfpos dst Positive mjfz dst Zero

#### **Comparison Jump Operations**

mjfedstEqualmjfgdstGreater ThanmjfgdstGreater Than or EqualmjfldstLess ThanmjfledstLess Than or EqualmjfnedstNot EqualmjfngdstNot Greater ThanmjfngdstNot Greater Than or EqualmjfngdstNot Less ThanmjfnldstNot Less ThanmjfnldstNot Less Than or EqualmjfodstOrderedmjfudstUnordered

#### **Floating Point Exceptions**

mjfdedstDivide-by-zeroExceptionmjfexcdstExceptionmjfimpdstImprecisemjfiodstIntegerOverflowmjfioedstInvalidOperationmjfoedstOverflowExceptionmjfuedstUnderflowException

Operation

if (condition) PC = dst

#### mjfcc

#### mjfcc

#### mjfcc

#### Description

When the PSW mode is not used, all jump instructions use the ASR to test the associated condition. If the condition tested is met, then the PC is replaced with the value specified by dst. In the PSW mode, the jump instructions use the PSW to check conditions. Also, some jump instructions are interpreted differently when assemblying in the PSW mode. These differences are noted in the following description.

Arithmetic jump operations. These operations are executed only after a floating point arithmetic operation or after one of the move or conversion operations. The conditions for these instructions are related to the result as stored in the destination. If the result is a NaN, as the result of an invalid operation, the jump is arbitrary.

**Comparison jump operations.** These operations are executed only after a floating point compare operation. Greater/less than means the first operand appearing in the compare instruction is greater/less than the second operand in the compare instruction.

In the PSW mode, the conditions NL, NLE, NG, and NGE are interpreted as GE, G, LE, and L respectively. The instruction, mjfu, is executed as a NOP, and mjfo is executed as an unconditional jump instruction. The rest of these instructions jump correctly if the operands are ordered but jump arbitrarily if the operands are unordered.

Floating point exceptions. When assembling a program in PSW mode, only the mjfio and mjfimp conditions are interpreted correctly, jump instructions with the other conditions are executed as NOPs.

# mmov10d

#### mmov10d

| Move Decimal Integer to Double |                                                                                                                                         |  |
|--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|--|
| Format                         | mmov10d src,dst                                                                                                                         |  |
| Operation                      | dst = CONVERT(src)                                                                                                                      |  |
| Description                    | The contents of $src$ are converted to a double floating point data type and that result is stored in the location specified by $dst$ . |  |
| Result                         | FLOATING-POSITIVE-ZERO                                                                                                                  |  |
| Types                          | FLOATING-NEGATIVE-ZERO                                                                                                                  |  |
|                                | FLOATING-POSITIVE-NONZERO                                                                                                               |  |
|                                | FLOATING-NEGATIVE-NONZERO                                                                                                               |  |
|                                |                                                                                                                                         |  |

#### mmov10s

#### mmov10s

| Move Decimal Integer to Single |                                                                                                                                  |  |
|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------|--|
| Format                         | mmov10s src,dst                                                                                                                  |  |
| Operation                      | dst = CONVERT(src)                                                                                                               |  |
| Description                    | The contents of $src$ are converted to single floating point type and that result is stored in the location specified by $dst$ . |  |
| Result                         | FLOATING-POSITIVE-ZERO                                                                                                           |  |
| Types                          | FLOATING-NEGATIVE-ZERO                                                                                                           |  |
|                                | FLOATING-POSITIVE-NONZERO                                                                                                        |  |
|                                | FLOATING-NEGATIVE-NONZERO                                                                                                        |  |
# mmov10x

# mmov10x

| Move Decimal Integer to Double Extended |                                                                                                                                                  |  |
|-----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Format                                  | mmov10x src,dst                                                                                                                                  |  |
| Operation                               | dst = CONVERT(src)                                                                                                                               |  |
| Description                             | The contents of $src$ are converted to a double extended floating point data type and that result is stored in the location specified by $dst$ . |  |
| Result                                  | FLOATING-POSITIVE-ZERO                                                                                                                           |  |
| Types                                   | FLOATING-NEGATIVE-ZERO                                                                                                                           |  |
|                                         | FLOATING-POSITIVE-NONZERO                                                                                                                        |  |
|                                         | FLOATING-NEGATIVE-NONZERO                                                                                                                        |  |

### mmovd10

### mmovd10

| Move Double to Decimal Integer |                                                                                                                                                                           |
|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Format                         | mmovd10 src,dst                                                                                                                                                           |
| Operation                      | dst = CONVERT(src)                                                                                                                                                        |
| Description                    | The contents of <i>src</i> are converted to decimal integer type and that result is stored in the location specified by <i>dst</i> . <i>dst</i> cannot be a MAU register. |
| Result<br>Types                | FLOATING-POSITIVE-ZERO<br>FLOATING-NEGATIVE-ZERO<br>FLOATING-POSITIVE-NONZERO<br>FLOATING-NEGATIVE-NONZERO                                                                |
|                                |                                                                                                                                                                           |

## mmovds

mmovds

.

Move Double to Single

| Format      | mmovds <i>src,dst</i>                                                                                                                   |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Operation   | dst = CONVERT(src)                                                                                                                      |
| Description | The contents of $src$ are converted to a single floating point data type and that result is stored in the location specified by $dst$ . |
| Result      | FLOATING-POSITIVE-ZERO                                                                                                                  |
| Types       | FLOATING-NEGATIVE-ZERO                                                                                                                  |
|             | FLOATING-POSITIVE-NONZERO                                                                                                               |
|             | FLOATING-NEGATIVE-NONZERO                                                                                                               |
|             |                                                                                                                                         |

Ę

## mmovdu

# mmovdu

| Move Double to Binary Unsigned Word Integer |                                                                                                                                                                                                                                                         |
|---------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Format                                      | mmovdu src,dst                                                                                                                                                                                                                                          |
| Operation                                   | dst = CONVERT(src)                                                                                                                                                                                                                                      |
| Description                                 | The contents of $src$ are converted to a unsigned word integer data type<br>and that result is stored in the location specified by $dst$ . $dst$ cannot be a<br>MAU register. This instruction cannot be used with floating-point<br>conditional jumps. |
| Result<br>Types                             | ZERO<br>POSITIVE                                                                                                                                                                                                                                        |

### mmovdw

#### mmovdw

### Move Double to Binary Signed Word Integer

Format mmovdw src,dst

**Operation** dst = CONVERT(src)

**Description** The contents of *src* are converted to a signed word integer data type and that result is stored in the location specified by *dst*. *dst* cannot be a MAU register.

Result ZERO Types POSITIVE NEGATIVE

## mmovdx

## mmovdx

| Move Double to Double Extended |                                                                                                                                                  |
|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Format                         | mmovdx src,dst                                                                                                                                   |
| Operation                      | dst = CONVERT(src)                                                                                                                               |
| Description                    | The contents of $src$ are converted to a double extended floating point data type and that result is stored in the location specified by $dst$ . |
| Result<br>Types                | FLOATING-POSITIVE-ZERO<br>FLOATING-NEGATIVE-ZERO<br>FLOATING-POSITIVE-NONZERO<br>FLOATING-NEGATIVE-NONZERO                                       |

# mmovfa mmovfd

# Move MAU Register to Memory

| Format      | mmovfa addressMove to ASR registermmovfd addressMove to data register                                                                                       |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation   | address = register                                                                                                                                          |
| Description | The contents of the specified MAU register are copied into the memory location specified by <i>address</i> . The memory operand is always a word data type. |

### mmovs10

# mmovs10

| Move Single to Decimal Integer |                                                                                                                                                                           |
|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Format                         | mmovs10 src,dst                                                                                                                                                           |
| Operation                      | dst = CONVERT(src)                                                                                                                                                        |
| Description                    | The contents of <i>src</i> are converted to decimal integer type and that result is stored in the location specified by <i>dst</i> . <i>dst</i> cannot be a MAU register. |
| Result                         | FLOATING-POSITIVE-ZERO                                                                                                                                                    |
| Types                          | FLOATING-NEGATIVE-ZERO                                                                                                                                                    |
|                                | FLOATING-POSITIVE-NONZERO                                                                                                                                                 |
|                                | FLOATING-NEGATIVE-NONZERO                                                                                                                                                 |

#### mmovsu

.

### mmovsu

| Move Single to Binary Unsigned Word Integer |                                                                                                                                                                               |
|---------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Format                                      | mmovsu src,dst                                                                                                                                                                |
| Operation                                   | dst = CONVERT(src)                                                                                                                                                            |
| Description                                 | The contents of $src$ are converted to a unsigned word integer data type<br>and that result is stored in the location specified by $dst$ . $dst$ cannot be a<br>MAU register. |
| Result<br>Types                             | ZERO<br>POSITIVE                                                                                                                                                              |

### mmovsw

#### mmovsw

| Move Single to Binary Signed Word Integer |                                                                                                                                                                        |  |
|-------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Format                                    | mmovsw src,dst                                                                                                                                                         |  |
| Operation                                 | dst = CONVERT(src)                                                                                                                                                     |  |
| Description                               | The contents of $src$ are converted to a signed word integer data type and that result is stored in the location specified by $dst$ . $dst$ cannot be an MAU register. |  |
| Result<br>Types                           | ZERO<br>POSITIVE<br>NEGATIVE                                                                                                                                           |  |

### mmovsx

#### mmovsx

| Move Single to Double Extended |                                                                                                                                                  |
|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Format                         | mmovsx src,dst                                                                                                                                   |
| Operation                      | dst = CONVERT(src)                                                                                                                               |
| Description                    | The contents of $src$ are converted to a double extended floating point data type and that result is stored in the location specified by $dst$ . |
| Result                         | FLOATING-POSITIVE-ZERO                                                                                                                           |
| Types                          | FLOATING-NEGATIVE-ZERO                                                                                                                           |
|                                | FLOATING-POSITIVE-NONZERO                                                                                                                        |
|                                | FLOATING-NEGATIVE-NONZERO                                                                                                                        |

### mmovta mmovtd

# Move Memory to MAU Register

| Format      | mmovta address Move to ASR register<br>mmovtd address Move to data register                                                                                |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation   | register = address                                                                                                                                         |
| Description | The contents of the memory location specified by <i>address</i> are copied into the specified MAU register. The memory operand is always a word data type. |

### mmovud

### mmovud

| Move Binary Unsigned Word Integer to Double |                                                                                                                                                                               |
|---------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Format                                      | mmovud src,dst                                                                                                                                                                |
| Operation                                   | dst = CONVERT(src)                                                                                                                                                            |
| Description                                 | The contents of $src$ are converted to a double floating point data type<br>and that result is stored in the location specified by $dst$ . $src$ cannot be a<br>MAU register. |
| Result<br>Types                             | FLOATING-POSITIVE-ZERO<br>FLOATING-POSITIVE-NONZERO                                                                                                                           |

#### mmoyus

#### mmovus

Move Binary Unsigned Word Integer to Single

Format mmovus src,dst

**Operation** dst = CONVERT(src)

**Description** The contents of *src* are converted to a floating single data type and that result is stored in the location specified by *dst*.

ResultFLOATING-POSITIVE-ZEROTypesFLOATING-POSITIVE-NONZERO

#### mmovux

#### mmovux

| Move Binary Unsigned Word Integer to Double Extended |                                                                                                                                                  |  |
|------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Format                                               | mmovux src,dst                                                                                                                                   |  |
| Operation                                            | dst = CONVERT(src)                                                                                                                               |  |
| Description                                          | The contents of $src$ are converted to a double extended floating point data type and that result is stored in the location specified by $dst$ . |  |
| Result                                               | FLOATING-POSITIVE-ZERO                                                                                                                           |  |
| Types                                                | FLOATING-NEGATIVE-ZERO                                                                                                                           |  |
|                                                      | FLOATING-POSITIVE-NONZERO                                                                                                                        |  |
|                                                      | FLOATING-NEGATIVE-NONZERO                                                                                                                        |  |

#### mmovwd

#### mmovwd

## Move Binary Signed Word Integer to Double

Format mmovwd src,dst

**Operation** dst = CONVERT(src)

**Description** The contents of *src* are converted to a double floating point data type and that result is stored in the location specified by *dst*.

Result Types FLOATING-POSITIVE-ZERO FLOATING-NEGATIVE-ZERO FLOATING-POSITIVE-NONZERO FLOATING-NEGATIVE-NONZERO

#### mmovws

#### mmovws

| Move Binary Signed Word Integer to Single |                                                                                                                                                   |  |
|-------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Format                                    | mmovws src,dst                                                                                                                                    |  |
| Operation                                 | dst = CONVERT(src)                                                                                                                                |  |
| Description                               | The contents of <i>src</i> are converted to a single floating point data type and that result is stored in the location specified by <i>dst</i> . |  |
| Result                                    | ZERO                                                                                                                                              |  |
| Types                                     | POSITIVE                                                                                                                                          |  |
|                                           | NEGATIVE                                                                                                                                          |  |

#### mmovwx

#### mmovwx

Move Binary Signed Word Integer to Double Extended

Formatmmovwx src, dstOperationdst = CONVERT(src)DescriptionThe contents of src are converted to a double extended floating point<br/>data type and that result is stored in the location specified by dst.ResultFLOATING-POSITIVE-ZERO<br/>FLOATING-NEGATIVE-ZERO<br/>FLOATING-POSITIVE-NONZERO<br/>FLOATING-NEGATIVE-NONZERO

#### mmovx10

#### mmovx10

### Move Double Extended to Decimal Integer

Format mmovx10 src,dst

**Operation** dst = CONVERT(src)

**Description** The contents of *src* are converted to decimal integer type and that result is stored in the location specified by *dst*.

ResultFLOATING-POSITIVE-ZEROTypesFLOATING-NEGATIVE-ZEROFLOATING-POSITIVE-NONZEROFLOATING-NEGATIVE-NONZERO

# mmovxd

.

## mmovxd

| Move Double Ex | tended to Double                                                                                                                        |  |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------|--|
| Format         | mmovxd src,dst                                                                                                                          |  |
| Operation      | dst = CONVERT(src)                                                                                                                      |  |
| Description    | The contents of $src$ are converted to a double floating point data type and that result is stored in the location specified by $dst$ . |  |
| Result         | FLOATING-POSITIVE-ZERO                                                                                                                  |  |
| Types          | FLOATING-NEGATIVE-ZERO                                                                                                                  |  |
|                | FLOATING-POSITIVE-NONZERO                                                                                                               |  |
|                | FLOATING-NEGATIVE-NONZERO                                                                                                               |  |

#### mmovxs

#### mmovxs

| Move Double Extended to Single |                                                                                                                                              |  |
|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|--|
| Format                         | mmovxs <i>src,dst</i>                                                                                                                        |  |
| Operation                      | dst = CONVERT(src)                                                                                                                           |  |
| Description                    | The contents of <i>src</i> are converted to a single floating point data type and that result is stored in the location specified by $dst$ . |  |
| Result                         | FLOATING-POSITIVE-ZERO                                                                                                                       |  |
| Types                          | FLOATING-NEGATIVE-ZERO                                                                                                                       |  |
|                                | FLOATING-POSITIVE-NONZERO                                                                                                                    |  |
|                                | FLOATING-NEGATIVE-NONZERO                                                                                                                    |  |

#### mmovxu

# Move Double Extended to Binary Unsigned Word Integer

Format mmovxu src,dst

**Operation** dst = CONVERT(src)

**Description** The contents of *src* are converted to a unsigned word integer data type and that result is stored in the location specified by *dst*.

ResultZEROTypesPOSITIVE

#### mmovxw

#### mmovxw

#### Move Double Extended to Binary Signed Word Integer

.

Format mmovxw src,dst

**Operation** dst = CONVERT(src)

**Description** The contents of *src* are converted to a signed word integer data type and that result is stored in the location specified by *dst*.

Result ZERO Types POSITIVE NEGATIVE

# FLOATING POINT SUPPORT MIS Instructions Summary by Function

## **MIS Instructions Summary by Function**

| Table 10-3. MIS Instructions Summary by Function |                                       |  |  |  |
|--------------------------------------------------|---------------------------------------|--|--|--|
| Mnemonic Name                                    |                                       |  |  |  |
|                                                  | Data Transfer Instructions            |  |  |  |
| Move:                                            |                                       |  |  |  |
| mmov10d                                          | Move decimal to double                |  |  |  |
| mmov10s                                          | Move decimal to single                |  |  |  |
| mmov10x                                          | Move decimal to double extended       |  |  |  |
| mmovd10                                          | Move double to decimal                |  |  |  |
| mmovds                                           | Move double to single                 |  |  |  |
| mmovdu                                           | Move double to unsigned word          |  |  |  |
| mmovdw                                           | Move double to signed word            |  |  |  |
| mmovdx                                           | Move double to double extended        |  |  |  |
| mmovs10                                          | Move single to decimal                |  |  |  |
| mmovsd                                           | Move single to double                 |  |  |  |
| mmovsu                                           | Move single to unsigned word          |  |  |  |
| mmovsw                                           | Move single to signed word            |  |  |  |
| mmovsx                                           | Move single to double extended        |  |  |  |
| mmovud                                           | Move unsigned word to double          |  |  |  |
| mmovus                                           | Move unsigned word to single          |  |  |  |
| mmovux                                           | Move unsigned word to double extended |  |  |  |
| mmovwd                                           | Move signed word to double            |  |  |  |
| mmovws                                           | Move signed word to single            |  |  |  |
| mmovwx                                           | Move signed word to double extended   |  |  |  |
| mmovx10                                          | Move double extended to decimal       |  |  |  |
| mmovxd                                           | Move double extended to double        |  |  |  |
| mmovxs                                           | Move double extended to single        |  |  |  |
| mmovxu                                           | Move double extended to unsigned word |  |  |  |
| mmovxw                                           | Move double extended to signed word   |  |  |  |
| mmovfa                                           | Move MAU's ASR register to memory     |  |  |  |
| mmovfd                                           | Move MAU's Data register to memory    |  |  |  |
| mmovta                                           | Move memory to MAU's ASR register     |  |  |  |
| mmovtd                                           | Move memory to MAU's Data register    |  |  |  |

| Table 10-3.         MIS Instructions Summary by Function (Continued) |                                                  |  |  |  |  |
|----------------------------------------------------------------------|--------------------------------------------------|--|--|--|--|
| Mnemonic                                                             | Name                                             |  |  |  |  |
|                                                                      | Arithmetic Instructions                          |  |  |  |  |
| Add:                                                                 |                                                  |  |  |  |  |
| mfaddd2                                                              | Add double, two operands                         |  |  |  |  |
| mfadds2                                                              | Add single, two operands                         |  |  |  |  |
| mfaddx2                                                              | Add double extended, two operands                |  |  |  |  |
| mfaddd3                                                              | Add double, three operands                       |  |  |  |  |
| mfadds3                                                              | Add single, three operands                       |  |  |  |  |
| mfaddx3                                                              | Add double extended, three operands              |  |  |  |  |
| Subtract:                                                            |                                                  |  |  |  |  |
| mfsubd2                                                              | Subtract double, two operands                    |  |  |  |  |
| mfsubs2                                                              | Subtract single, two operands                    |  |  |  |  |
| mfsubx2                                                              | Subtract double extended, two operands           |  |  |  |  |
| mfsubd3                                                              | Subtract double, three operands                  |  |  |  |  |
| mfsubs3                                                              | Subtract single, three operands                  |  |  |  |  |
| mfsubx3                                                              | Subtract double extended, three operands         |  |  |  |  |
| Multiply:                                                            |                                                  |  |  |  |  |
| mfmuld2                                                              | Multiply double, two operands                    |  |  |  |  |
| mfmuls2                                                              | Multiply single, two operands                    |  |  |  |  |
| mfmulx2                                                              | Multiply double extended, two operands           |  |  |  |  |
| mfmuld3                                                              | Multiply double, three operands                  |  |  |  |  |
| mfmuls3                                                              | Multiply single, three operands                  |  |  |  |  |
| mfmulx3                                                              | Multiply double extended, three operands         |  |  |  |  |
| Divide:                                                              |                                                  |  |  |  |  |
| mfdivd2                                                              | Divide double, two operands                      |  |  |  |  |
| mfdivs2                                                              | Divide single, two operands                      |  |  |  |  |
| mfdivx2                                                              | Divide double extended, two operands             |  |  |  |  |
| mfdivd3                                                              | Divide double, three operands                    |  |  |  |  |
| mfdivs3                                                              | Divide single, three operands                    |  |  |  |  |
| mfdivx3                                                              | Divide double extended, three operands           |  |  |  |  |
| <b>Remainder Divide:</b>                                             |                                                  |  |  |  |  |
| mfremd2                                                              | Remainder divide double, two operands            |  |  |  |  |
| mfrems2                                                              | Remainder divide single, two operands            |  |  |  |  |
| mfremx2                                                              | Remainder divide double extended, two operands   |  |  |  |  |
| mfremd3                                                              | Remainder divide double, three operands          |  |  |  |  |
| mfrems3                                                              | Remainder divide single, three operands          |  |  |  |  |
| mfremx3                                                              | Remainder divide double extended, three operands |  |  |  |  |

### FLOATING POINT SUPPORT MIS Instructions Summary by Function

| Table 10-3.         MIS Instructions Summary by Function (Continued) |                                             |  |  |
|----------------------------------------------------------------------|---------------------------------------------|--|--|
| Mnemonic                                                             | Name                                        |  |  |
| Negate:                                                              |                                             |  |  |
| mfnegd1                                                              | Negate double, one operand                  |  |  |
| mfnegs1                                                              | Negate single, one operand                  |  |  |
| mfnegx1                                                              | Negate double extended, one operand         |  |  |
| mfnegd2                                                              | Negate double, two operands                 |  |  |
| mfnegs2                                                              | Negate single, two operands                 |  |  |
| mfnegx2                                                              | Negate double extended, two operands        |  |  |
| Round:                                                               |                                             |  |  |
| mfrndd1                                                              | Round double, one operand                   |  |  |
| mfrnds1                                                              | Round single, one operand                   |  |  |
| mfrndx1                                                              | Round double extended, one operand          |  |  |
| mfrndd2                                                              | Round double, two operands                  |  |  |
| mfrnds2                                                              | Round single, two operands                  |  |  |
| mfrndx2                                                              | Round double extended, two operands         |  |  |
| Square Root:                                                         |                                             |  |  |
| mfsqrd1                                                              | Square root double, one operand             |  |  |
| mfsqrs1                                                              | Square root single, one operand             |  |  |
| mfsqrx1                                                              | Square root double extended, one operand    |  |  |
| mfsqrd2                                                              | Square root double, two operands            |  |  |
| mfsqrs2                                                              | Square root single, two operands            |  |  |
| mfsqrx2                                                              | Square root double extended, two operands   |  |  |
| Logical Instructions                                                 |                                             |  |  |
| Compare:                                                             |                                             |  |  |
| mfcmpd                                                               | Compare double                              |  |  |
| mfcmps                                                               | Compare single                              |  |  |
| mfcmpx                                                               | Compare double extended                     |  |  |
| mfcmptd                                                              | Compare double with trap operation          |  |  |
| mfcmpts                                                              | Compare single with trap operation          |  |  |
| mfcmptx                                                              | Compare double extended with trap operation |  |  |

# FLOATING POINT SUPPORT MIS Instructions Summary by Function

,

| Table 10-3. MIS Instructions Summary by Function (Continued) |                                     |  |
|--------------------------------------------------------------|-------------------------------------|--|
| Mnemonic                                                     | Name                                |  |
|                                                              | Control Transfer Instructions       |  |
| mjfde                                                        | Jump if divide-by-zero exception    |  |
| mjfe                                                         | Jump if equal                       |  |
| mjfexp                                                       | Jump if exception                   |  |
| mjfg                                                         | Jump if greater than                |  |
| mjfge                                                        | Jump if greater than or equal       |  |
| mjimp                                                        | Jump if imprecise                   |  |
| mjfio                                                        | Jump if integer overflow            |  |
| mjfioe                                                       | Jump if invalid operation exception |  |
| mjfl                                                         | Jump if less than                   |  |
| mjfle                                                        | Jump if less than or equal          |  |
| mjfne                                                        | Jump if not equal                   |  |
| mjfneg                                                       | Jump if negative                    |  |
| mjfng                                                        | Jump if not greater than            |  |
| mjfnge                                                       | Jump if not greater than or equal   |  |
| mjfnl                                                        | Jump if not less than               |  |
| mjfnle                                                       | Jump if not less than or equal      |  |
| mjfnz                                                        | Jump if not zero                    |  |
| mjfo                                                         | Jump if ordered                     |  |
| mjfoe                                                        | Jump if overflow exception          |  |
| mjfpos                                                       | Jump if positive                    |  |
| mjfu                                                         | Jump if unordered                   |  |
| mjfue                                                        | Jump if underflow exception         |  |
| mjfz                                                         | Jump if zero                        |  |

# FLOATING POINT SUPPORT

MIS Instructions Summary by Mnemonic

MIS Instructions Summary by Mnemonic

| Table 10-4. MIS Instructions Summary by Mnemonic |                                              |  |  |  |  |
|--------------------------------------------------|----------------------------------------------|--|--|--|--|
| Mnemonic                                         | Name                                         |  |  |  |  |
| mfabsd1                                          | Absolute value double, one operand           |  |  |  |  |
| mfabsd2                                          | Absolute value double, two operands          |  |  |  |  |
| mfabss1                                          | Absolute value single, one operand           |  |  |  |  |
| mfabss2                                          | Absolute value single, two operands          |  |  |  |  |
| mfabsx1                                          | Absolute value double extended, one operand  |  |  |  |  |
| mfabsx2                                          | Absolute value double extended, two operands |  |  |  |  |
| mfaddd2                                          | Add double, two operands                     |  |  |  |  |
| mfaddd3                                          | Add double, three operands                   |  |  |  |  |
| mfadds2                                          | Add single, two operands                     |  |  |  |  |
| mfadds3                                          | Add single, three operands                   |  |  |  |  |
| mfaddx2                                          | Add double extended, two operands            |  |  |  |  |
| mfaddx3                                          | Add double extended, three operands          |  |  |  |  |
| mfcmpd                                           | Compare double                               |  |  |  |  |
| mfcmps                                           | Compare single                               |  |  |  |  |
| mfcmptd                                          | Compare double with trap operation           |  |  |  |  |
| mfcmpts                                          | Compare single with trap operation           |  |  |  |  |
| mfcmptx                                          | Compare double extended with trap operation  |  |  |  |  |
| mfcmpx                                           | Compare double extended                      |  |  |  |  |
| mfdivd2                                          | Divide double, two operands                  |  |  |  |  |
| mfdivd3                                          | Divide double, three operands                |  |  |  |  |
| mfdivs2                                          | Divide single, two operands                  |  |  |  |  |
| mfdivs3                                          | Divide single, three operands                |  |  |  |  |
| mfdivx2                                          | Divide double extended, two operands         |  |  |  |  |
| mfdivx3                                          | Divide double extended, three operands       |  |  |  |  |
| mfmuld2                                          | Multiply double, two operands                |  |  |  |  |
| mfmuld3                                          | Multiply double, three operands              |  |  |  |  |
| mfmuls2                                          | Multiply single, two operands                |  |  |  |  |
| mfmuls3                                          | Multiply single, three operands              |  |  |  |  |
| mfmulx2                                          | Multiply double extended, two operands       |  |  |  |  |
| mfmulx3                                          | Multiply double extended, three operands     |  |  |  |  |
| mfnegd1                                          | Negate double, one operand                   |  |  |  |  |
| mfnegd2                                          | Negate double, two operands                  |  |  |  |  |
| mfnegs1                                          | Negate single, one operand                   |  |  |  |  |
| mfnegs2                                          | Negate single, two operands                  |  |  |  |  |
| mfnegx1                                          | Negate double extended, one operand          |  |  |  |  |
| mfnegx2                                          | Negate double extended, two operands         |  |  |  |  |

# FLOATING POINT SUPPORT MIS Instructions Summary by Mnemonic

| Table 10-4. MIS Instructions Summary by Mnemonic (Continued) |                                                  |  |  |  |  |
|--------------------------------------------------------------|--------------------------------------------------|--|--|--|--|
| Mnemonic                                                     | Name                                             |  |  |  |  |
| mfremd2                                                      | Remainder divide double, two operands            |  |  |  |  |
| mfremd3                                                      | Remainder divide double, three operands          |  |  |  |  |
| mfrems2                                                      | Remainder divide single, two operands            |  |  |  |  |
| mfrems3                                                      | Remainder divide single, three operands          |  |  |  |  |
| mfremx2                                                      | Remainder divide double extended, two operands   |  |  |  |  |
| mfremx3                                                      | Remainder divide double extended, three operands |  |  |  |  |
| mfrndd1                                                      | Round double, one operand                        |  |  |  |  |
| mfrndd2                                                      | Round double, two operands                       |  |  |  |  |
| mfrnds1                                                      | Round single, one operand                        |  |  |  |  |
| mfrnds2                                                      | Round single, two operands                       |  |  |  |  |
| mfrndx1                                                      | Round double extended, one operand               |  |  |  |  |
| mfrndx2                                                      | Round double extended, two operands              |  |  |  |  |
| mfsqrd1                                                      | Square root double, one operand                  |  |  |  |  |
| mfsqrd2                                                      | Square root double, two operands                 |  |  |  |  |
| mfsqrs1                                                      | Square root single, one operand                  |  |  |  |  |
| mfsqrs2                                                      | Square root single, two operands                 |  |  |  |  |
| mfsqrx1                                                      | Square root double extended, one operand         |  |  |  |  |
| mfsqrx2                                                      | Square root double extended, two operands        |  |  |  |  |
| mfsubd2                                                      | Subtract double, two operands                    |  |  |  |  |
| mfsubd3                                                      | Subtract double, three operands                  |  |  |  |  |
| mfsubs2                                                      | Subtract single, two operands                    |  |  |  |  |
| mfsubs3                                                      | Subtract single, three operands                  |  |  |  |  |
| mfsubx2                                                      | Subtract double extended, two operands           |  |  |  |  |
| mfsubx3                                                      | Subtract double extended, three operands         |  |  |  |  |
| mjfde                                                        | Jump if divide-by-zero exception                 |  |  |  |  |
| mjfe                                                         | Jump if equal                                    |  |  |  |  |
| mjfexp                                                       | Jump if exception                                |  |  |  |  |
| mjfg                                                         | Jump if greater than                             |  |  |  |  |
| mjfge                                                        | Jump if greater than or equal                    |  |  |  |  |
| mjfimp                                                       | Jump if imprecise                                |  |  |  |  |
| mjfio                                                        | Jump if integer overflow                         |  |  |  |  |
| mjfioe                                                       | Jump if invalid operation exception              |  |  |  |  |
| mjfl                                                         | Jump if less than                                |  |  |  |  |
| mjfle                                                        | Jump if less than or equal                       |  |  |  |  |
| mjfne                                                        | Jump if not equal                                |  |  |  |  |
| mjfneg                                                       | Jump if negative                                 |  |  |  |  |
| mjfng                                                        | Jump if not greater than                         |  |  |  |  |
| mjfnge                                                       | Jump if not greater than or equal                |  |  |  |  |
| mjfnl                                                        | Jump if not less than                            |  |  |  |  |

.

| Table 10-4. MIS Instructions Summary by Mnemonic (Continued) |                                       |  |  |  |
|--------------------------------------------------------------|---------------------------------------|--|--|--|
| Mnemonic                                                     | Name                                  |  |  |  |
| mjfnle                                                       | Jump if not less than or equal        |  |  |  |
| mjfnz                                                        | Jump if not zero                      |  |  |  |
| mjfo                                                         | Jump if ordered                       |  |  |  |
| mjfoe                                                        | Jump if overflow exception            |  |  |  |
| mjfpos                                                       | Jump if positive                      |  |  |  |
| mjfu                                                         | Jump if unordered                     |  |  |  |
| mjfue                                                        | Jump if underflow exception           |  |  |  |
| mjfz                                                         | Jump if zero                          |  |  |  |
| mmov10d                                                      | Move decimal to double                |  |  |  |
| mmov10s                                                      | Move decimal to single                |  |  |  |
| mmov10x                                                      | Move decimal to double extended       |  |  |  |
| mmovd10                                                      | Move double to decimal                |  |  |  |
| mmovds                                                       | Move double to single                 |  |  |  |
| mmovdu                                                       | Move double to unsigned word          |  |  |  |
| mmovdw                                                       | Move double to signed word            |  |  |  |
| mmovdx                                                       | Move double to double extended        |  |  |  |
| mmovfa                                                       | Move MAU's ASR register to memory     |  |  |  |
| mmovfd                                                       | Move MAU's Data register to memory    |  |  |  |
| mmovs10                                                      | Move single to decimal                |  |  |  |
| mmovsd                                                       | Move single to double                 |  |  |  |
| mmovsu                                                       | Move single to unsigned word          |  |  |  |
| mmovsw                                                       | Move single to signed word            |  |  |  |
| mmovsx                                                       | Move single to double extended        |  |  |  |
| mmovta                                                       | Move memory to MAU's ASR register     |  |  |  |
| mmovtd                                                       | Move memory to MAU's Data register    |  |  |  |
| mmovud                                                       | Move unsigned word to double          |  |  |  |
| mmovus                                                       | Move unsigned word to single          |  |  |  |
| mmovux                                                       | Move unsigned word to double extended |  |  |  |
| mmovwd                                                       | Move signed word to double            |  |  |  |
| mmovws                                                       | Move signed word to single            |  |  |  |
| mmovwx                                                       | Move signed word to double extended   |  |  |  |
| mmovx10                                                      | Move double extended to decimal       |  |  |  |
| mmovxd                                                       | Move double extended to double        |  |  |  |
| mmovxs                                                       | Move double extended to single        |  |  |  |
| mmovxu                                                       | Move double extended to unsigned word |  |  |  |
| mmovxw                                                       | Move double extended to signed word   |  |  |  |

#### **10.2 FLOATING POINT EMULATION LIBRARY**

The following describes the available floating point emulation (FPE) library that can be used with the assembler (as). The library must be used with 3B Computers which do not contain a WE 32106 Math Acceleration Unit. The FPE library can be used with computers containing a MAU, but for improved performance, the MIS instructions should be used.

The library contains a collection of functions accessible to the compiler (cc) or the assembler (as) and provides floating point primitives (e.g., addition, multiplication) and conversion between different data formats as defined by the IEEE standards. In addition, routines are provided to examine and set the rounding mode, to provide information in case of floating point exceptions, and to change the behavior of floating point exceptions.

In addition, this section discusses the data types used by the FPE library and provides descriptions of each FPE library routine in alphabetical order.

#### **10.2.1** Assembly Language Support

Support of floating point operations for assembly language is also provided by the library libc.a. To gain access to the floating point library from an assembly language program, the programmer must first assemble the program into an object module (i.e., a .o file). Next, the programmer uses the compiler (cc) to automatically link the required floating point functions off bibc.a as follows:

| $\triangleleft$ | 2 |        | 4 C | 1) |
|-----------------|---|--------|-----|----|
| (°1)            | ſ | tru    | tro | Μ  |
| cc file.o       | ^ | '''''' | •   |    |

where file o is the relocatable o file which defines the integral valued function main() as the entry point of user code. This links in the required <u>crt0.0</u> floating point startup, emulation routines, and if needed, the fault handling routines.  $frrt 0 \circ$ ?

#### 10.2.2 Data Type

The floating point data types supported by the FPE library are single and double as described in 10.1.2. Data Types.

#### 10.2.3 Floating Point Environment and Exception Handling

The floating point subsystem is based on the IEEE floating point standard. In this format, the largest and the smallest representable magnitudes are (as defined in the header file values.h):

| #define MAXDOUBLE | 1.79769313486231470e+308          |
|-------------------|-----------------------------------|
| #define MAXFLOAT  | ((float) 3.40282345538538860e+38) |
| #define MINDOUBLE | 4.940656458412465544e-324         |
| #define MINFLOAT  | ((float)1.40129846432481707e-45)  |

Most programmers of the C language need not be concerned with the details of the floating point environment. If programmers do nothing special to handle floating point exceptions everything will work fine and if floating point traps occur (e.g., if the program tries to do a divide by zero), the program will core dump with a SIGFPE. The rest of this section discusses more details of the floating point environment and exception handling.

A new header file **ieeefp.h** has been added which defines the interface for the floating point exception and environment control. This header defines three interfaces:

- Rounding control
- Exception control
- Exception handling

The floating point arithmetic provides four rounding modes, which affect the result of most floating point operations. These modes are also defined in the header **ieeefp.h**.

```
typedef enum fp_rnd {
   FP_RN = 0, /* round to nearest representable number, tie -> even */
   FP_RP = 1, /* round toward plus infinity */
   FP_RM = 2, /* round toward minus infinity */
   FP_RZ = 3 /* round toward zero (truncate) */
} fp rnd;
```

Programmers can check the current rounding mode with the function:

fp rnd fpgetround(); /\* return current rounding mode \*/

Programmers can change the rounding mode for floating point operations by the function:

fp\_rnd fpsetround(round); /\* set rounding mode, return previous \*/ fp\_rnd round;

The default rounding mode is round-to-nearest. Note that in C, floating point to integer conversions are always done by truncation and the current rounding mode has no effect on these operations.

The floating point provides two kinds of special representation:

- 1. Infinity. Positive infinity in a format compares greater than all other representable numbers in the same format. Arithmetic operations on infinities are quite intuitive, e.g., adding any representable number to infinity is a valid operation, the result is positive infinity. Subtracting positive infinity from itself is invalid. If some arithmetic operation overflows and the overflow trap is disabled, in some rounding modes the delivered result is infinity.
- 2. Not-a-Number (NaN). These floating point representations are not numbers, they may be used to carry diagnostic informations. There are two kinds of NaNs, signaling NaNs and quiet NaNs. Signaling NaNs raise the invalid operation exception whenever they are used as operands in floating point operations. Quiet NaNs

propagate through most operations without raising any exception, the result of these operation is the same quiet NaN. NaNs are sometimes produced by the arithmetic operations themselves, e.g., 0.0 divided by 0.0 when the invalid operation trap is disabled produces a quiet NaN.

Floating point operations can lead to certain exception conditions, divide by zero is a common example. There are five types of floating point exceptions:

- 1. Divide by zero exception. This exception happens when a nonzero number is divided by floating point zero.
- 2. Invalid operation exception. Operations on signaling NaNs; zero divided by zero; infinity subtracted from infinity; infinity divided by infinity; and when a quiet NaN is compared with the greater or lesser predicates, all raise invalid exceptions.
- 3. Overflow exception. This exception occurs when the result of any floating point operation is too large in magnitude to fit in the intended destination.
- 4. Underflow exception. When the underflow trap is enabled, underflow exception is signaled when a result of some operation is a tiny nonzero number smaller than the smallest representable number. When the underflow trap is disabled, underflow exception occurs only when both tinyness and loss of accuracy are detected.
- 5. Inexact or imprecise exception. This exception is signaled if the rounded result of an operation is not identical to the infinitely precise result. Inexact exceptions are quite common (e.g., 1.0/3.0 is an inexact operation). Inexact exception also occurs when the operation overflows without an overflow trap.

Note: The above examples are not an exhaustive list of the conditions when an exception can occur.

There is a sticky bit associated with each of these exceptions. Whenever any of these exceptions occur, the corresponding sticky bit is set (=1). The sticky bits are all cleared at the start of a process. After that, they are never cleared by the floating point system, just set to remember that an exception occurred.

Programmers can check the status of the sticky bits by using the function:

fp\_except fpgetsticky(); /\* return logged exceptions \*/

fp\_except can have the following (not exclusive) values:

#define fp\_except int
#define FP\_X\_INV 0x10 /\* invalid operation exception \*/
#define FP\_X\_OFL 0x08 /\* overflow exception \*/
#define FP\_X\_UFL 0x04 /\* underflow exception \*/
#define FP\_X\_DZ 0x02 /\* divide-by-zero exception \*/
#define FP\_X\_IMP 0x01 /\* imprecise (loss of precision) exception \*/

Programmers can change the sticky bits by using the function:

fp\_except fpsetsticky(sticky); /\* change logged exceptions \*/
fp\_except sticky;

### FLOATING POINT SUPPORT Floating Point Environment and Exception Handling

There is also a trap-enable bit (mask bit) associated with each exception. When an exception occurs, if the corresponding trap bit is enabled (=1), a trap takes place. Programmers can check the status of these mask bits by using the function:

fp except fpgetmask(); /\* current exception mask \*/

Programmers can also selectively enable or disable any of the exceptions by calling the function:

fp\_except fpsetmask(mask); /\* set mask, return previous mask \*/
fp except mask;

with appropriate mask values.

The default setting of the mask bits are: divide-by-zero, invalid operation, and overflow traps enabled.

The only cases where two floating point exceptions can occur together are inexact with underflow and inexact with overflow. In these cases, the trap for the inexact is taken only if the other trap is disabled.

When the trap is enabled, floating point exceptions are signaled through the standard UNIX System mechanism, a SIGFPE is sent to the user process. If the programmer intends to handle the trap and proceed with the program, the programmer must include the file **ieeefp.h** in at least one module of the program. The programmer can attach a handler to SIGFPE by calling the UNIX System signal(2) routine.

When a floating-point exception handler is entered, the global variables:

\_fpftype -- floating-point fault type, and fpfault -- pointer to floating-point exception structure

are established. \_fpftype identifies the primary exception type. Possible values for \_fpftype are FP\_UFLW, FP\_DIVZ, INT\_DIVZ etc. (see ieeefp.h).

\_fpfault points to a structure which provides all other information about the floating point operation. The information pointed to by \_fpfault includes:

- 1. the type of operation being performed
- 2. the types and values of the operands
- 3. the type of a trapped value (if any)
- 4. the desired type of the result.

The structure has the form:

struct fp\_fault { fp\_op operation; fp\_dunion operand[2]; fp\_dunion t\_value; fp\_dunion result;



}; extern struct fp fault \* fpfault;

The operation field identifies the floating point operation which raised the exception. The possible values are included in **ieeefp.h**. fp\_dunion is a discriminated union which contains information about the type/format of the operands (or result) (e.g., whether the operand is in single precision or double precision). It also contains the actual values. See **ieeefp.h** for exact definitions of the different members of the union.

A user handler has the information about the floating point operation, the operands, the computed result, and the format in which the result is to be returned. The user handler can supply a result in the right format and when the handler returns, this result is used to complete the floating point operation.

#### 10.2.4 Library Listings

The following presents descriptions of each floating point emulation function call. The descriptions are in alphabetical order and any function that operates on more than one type of operand, single or double, are listed on the same page. (For quick reference to the function calls by function or mnemonic see the following: FPE Function Call Summary By Function and FPE Function Call Summary By Mnemonic.) The notation used in the listings is described.

#### Notation

Each function call description contains four parts: name, synopsis, description, and exceptions.

Name. Gives the name of the function call.

Synopsis. Presents the syntax for the function call, including any required spacing and punctuation. If the function has single or double forms, both forms are presented.

**Description.** Describes the function performed. Also, any additional explanation is included where necessary.

Exceptions. Lists the possible exceptions which may happen. If an exception happens the associated flags in the asr word are set.

#### **FPE Function Call Descriptions**

The FPE function calls are described in detail on the following pages. Before using these routines, the programmer must be aware of the following special cases:

1. Only the comparison calls affect the Process Status Word (PSW) bits in the WE 32100 Microprocessor (CPU). Other floating point calls (e.g., fadd()) do not

### FLOATING POINT SUPPORT FPE Function Call Descriptions

set any condition codes. For the code

if (float expression) statement;

generates a specific comparison with 0.0; i.e., the above test is treated as:

if (float expression != 0.0) statement;

In general, for floating point operands, jump on zero/positive may not account for possible negative zeros; jump on equality does not have this problem.

- When an exception occurs, the corresponding sticky bit is set. Additional behavior is dependent on the corresponding trap bit being set/enabled (=1) or masked/disabled (=0). A trap takes place if the mask is enabled. Note the distinction between exceptions and traps. If the trap is disabled, additional behavior depends on the operation being performed, as well as the rounding mode in effect.
- 3. The only cases where two exceptions can occur simultaneously are inexact with overflow and inexact with underflow. In these cases, the trap for inexact (if enabled) occurs only if the trap for overflow/underflow is disabled.
- 4. Signaling and quiet NaNs (Not a Number) are distinguished by the most significant bit in the explicit fraction part of the format. If this bit is zero, then the NaN is a signaling NaN, or else it is a quiet NaN.
- 5. When a quiet NaN has to be generated, it has a positive sign. All the fraction bits are set to one (1).
- 6. For format conversion of quiet NaNs (e.g., in \_fdtos() ), the least significant part of the fraction of the quiet NaN that fits in the fraction of the destination (less the quiet NaN bit) is placed left justified in the result.
- 7. If both operands are quiet NaNs, and a result is to be delivered, the resulting quiet NaN is the first argument to the function.
- 8. Quiet NaNs propagate through function calls without raising exceptions (except fcmptd() and fcmpts()).
- 9. The arithmetic routines never change the exception mask bits, nor clear the exception sticky bits. The programmer is provided with a set of routines to set the required masks and clear the sticky bits.
- 10. The float arguments to the functions and the functions returning float values are treated specially in the sense that they are not converted to double arguments/results. Normally, single precision compares and conversions are used, all other operations are performed in double precision.

i.
### \_faddd() \_fadds()

\_faddd() \_fadds()

#### NAME

\_faddd - Floating Add Double \_fadds - Floating Add Single

### SYNOPSIS

\_faddd(src1,src2)

\_fadds(src1,src2)

#### DESCRIPTION

Performs double/single precision addition of the double/single precision operands and returns a result in the same format.

#### **EXCEPTIONS**

Invalid-operation:

- Operations involving signaling NaN(s)
- Magnitude subtraction of infinities (e.g., +/-infinity).

Overflow

Underflow

Inexact

### \_fcmpd() \_fcmps()

#### NAME

\_fcmpd - Floating Compare Operands Double fcmps - Floating Compare Operands Single

### SYNOPSIS

\_fcmpd(src1,src2)

\_fcmps(src1,src2)

#### DESCRIPTION

Compare the source operands. These functions are used for comparison predicates involving == and != (as well as comparison predicates like >?, if the languages are extended to include these).

The only difference between \_fcmpd() and \_fcmptd() is that: for \_fcmpd(), quiet NaNs do not raise invalid operation exceptions Only signaling NaNs raise invalid exceptions.

These functions return with the PSW flags in the CPU set as:

• N = 1 if src1 < src2, else 0

• Z = 1 if src1 == src2, else 0

Comparisons are always exact and never underflow or overflow.

-infinity < all finite numbers < +infinity

(+0.0 = -0.0) and (+infinity = +infinity) compare equal

Every NaN compares unordered with everything including itself.

Unordered condition raises the invalid operation exception.

### **EXCEPTIONS**

For comparisons involving signaling NaN(s).

10-70

### \_fcmptd() \_fcmpts()

#### NAME

\_fcmptd - Floating Compare With Exceptions Double fcmpts - Floating Compare With Exceptions Single

#### SYNOPSIS

\_fcmptd(src1,src2)

fcmpts(src1,src2)

### DESCRIPTION

Compare with exceptions. This is the CMPE instruction of the MAU hardware. Compilers generate this call for the comparison predicates involving > and <.

These functions return with the PSW flags in the CPU set as:

- N = 1 if src1 < src2, else 0
- Z = 1 if src1 == src2, else 0

Comparisons are always exact and never underflow or overflow.

-infinity < all finite numbers < +infinity

(+0.0 = -0.0) and (+infinity = +infinity) compare equal

Every NaN compares unordered with everything including itself.

Unordered condition raises the invalid operation exception.

### **EXCEPTIONS**

Invalid-operation: Comparison involving a signaling or quiet NaN(s) where at least one operand is a NaN.

### \_fdivd() \_fdivs()

#### NAME

\_fdivd - Floating Divide Double \_fdivs - Floating Divide Single

### SYNOPSIS

\_fdivd(src1,src2)

\_fdivs(src1,src2)

### DESCRIPTION

Performs double/single precision division of the double/single precision operands and returns a result in the same format.

### **EXCEPTIONS**

Divide by zero: when a nonzero number is divided by zero. If no trap occurs, the result is correctly signed infinity.

· · · · · · · ·

Invali

### \_fdtos()

#### NAME

fdtos - Convert Double to Single

### SYNOPSIS

\_fdtos(src)

### DESCRIPTION

Convert double precision operand src to single precision format.

When a double precision quiet NaN is converted to single precision, the result contains the 22 least significant fraction bits of the source.

### **EXCEPTIONS**

Invalid-operation: for signaling NaNs.

Overflow

Underflow

Inexact

\_fltod() \_fltos() \_fltod() \_fltos()

### NAME

\_fltod - Convert Integer to Double \_fltos - Convert Integer to Single

#### SYNOPSIS

\_fltod(src)

fltos(src)

### DESCRIPTION

Convert integer operand src to double/single precision floating point format.

### **EXCEPTIONS**

Inexact for \_fltos().

### \_fmuld() \_fmuls()

#### NAME

\_fmuld — Floating Multiply Double \_fmuls — Floating Multiply Single

### SYNOPSIS

\_fmuld(src1,src2)

\_fmuls(src1,src2)

### DESCRIPTION

Performs double/single precision multiplication of the double/single precision operands and returns a result in the same format.

### **EXCEPTIONS**

Invalid-operation:

- Operations involving signaling NaN(s)
- $0.0 \times \text{Infinity}$

Overflow

Underflow

Inexact

### \_fnegd() \_fnegs()

#### NAME

\_fnegd - Negate Double \_fnegs - Negate Single

### SYNOPSIS

\_fnegd(src)

\_fnegs(src)

### DESCRIPTION

Negate the double/single precision operand.

\_fnegd() is just src with the sign reversed, not (0.0 - src). It is treated as a non-arithmetic operation and is not checked for any exceptions.

### **EXCEPTIONS**

None

### \_fstod()

#### NAME

\_fstod - Convert Single to Double

### SYNOPSIS

\_fstod(src)

### DESCRIPTION

Convert single precision operand src to double precision format.

This is one instance of the MAU operation MOVE.

When a single precision quiet NaN is converted to double precision, it contains the 22 diagnostic bits of the float source placed left justified.

### **EXCEPTIONS**

Invalid-operation: for signaling NaNs.

### \_fsubd() fsubs()

### NAME

\_fsubd - Floating Subtract Double \_fsubs - Floating Subtract Single

### SYNOPSIS

\_fsubd(src1,src2)

\_fsubs(src1,src2)

### DESCRIPTION

Performs double/single precision subtraction of the double/single precision operands and returns a result in the same format.

### **EXCEPTIONS**

Invalid-operation:

- Operations involving signaling NaN(s)
- Magnitude subtraction of infinities (e.g., +infinity +infinity).

Overflow

Underflow

Inexact

### \_ftdtol() \_ftstol()

.

#### NAME

\_ftdtol - Convert Double to Integer ftstol - Convert Single to Integer

### SYNOPSIS

\_ftdtol(src)

\_ftstol(src)

#### DESCRIPTION

Convert double/single precision operand src to integer format with rounding mode set to to zero (truncation).

Negative zero is converted to integer zero.

If integer overflow occurs, with traps disabled, the result is undefined.

If invalid operation exception occurs, and the trap is disabled, the result is undefined.

Conversion of negative floating point values to unsigned integer returns integer zero.

#### **EXCEPTIONS**

Invalid-operation: if the source operand is NaN or infinity.

Integer overflow.

### \_ftdtou() \_ftstou()

#### NAME

\_ftdtou - Convert Double to Unsigned Integer ftstou - Convert Single to Unsigned Integer

#### SYNOPSIS

\_ftdtou(src)

\_ftstou(src)

#### DESCRIPTION

Convert double/single precision operand src to unsigned integer format with rounding mode set to *to zero* (truncation).

Negative zero is converted to integer zero.

If integer overflow occurs, with traps disabled, the result is undefined.

If invalid operation exception occurs, and the trap is disabled, the result is undefined.

Conversion of negative floating point values to unsigned integer returns integer zero.

Truncation is used to convert floating point numbers to integers.

#### **EXCEPTIONS**

Invalid-operation: if the source operand is NaN or infinity.

Integer overflow.

### \_futod() \_futos()

\_

\_futod() \_futos()

#### NAME

\_futod - Convert Unsigned Integer to Double \_futos - Convert Unsigned Integer to Single

### SYNOPSIS

\_futod(src)

\_futos(src)

### DESCRIPTION

Convert unsigned integer operand src to double/single precision floating point format.

### **EXCEPTIONS**

Inexact for \_futos().

### FPE Function Call Summary by Function

### isnand() isnanf()

isnand() isnanf()

.

#### NAME

isnand – Check for NaN Double isnanf – Check for NaN Single

### SYNOPSIS

isnand(src)

isnanf(src)

#### DESCRIPTION

Returns true (1) if src is a NaN, or else returns false (0). Does not generate any exception, even for signaling NaNs.

#### EXCEPTIONS

None

### FLOATING POINT SUPPORT FPE Function Call Summary by Function

| Table 10-5. FPE Function Call Summary by Function |                                    |  |
|---------------------------------------------------|------------------------------------|--|
| Mnemonic                                          | Name                               |  |
|                                                   | Data Conversion Function Calls     |  |
| fdtos                                             | Convert double to single           |  |
| fstod                                             | Convert single to double           |  |
| fltod                                             | Convert integer to double          |  |
| fltos                                             | Convert integer to single          |  |
| ftdtol                                            | Convert double to integer          |  |
| ftstol                                            | Convert singel to integer          |  |
| ftdtou                                            | Convert double to unsigned integer |  |
| ftstou                                            | Convert single to unsigned integer |  |
|                                                   | Arithmetic Function Calls          |  |
| Add:                                              |                                    |  |
| _faddd                                            | Add double                         |  |
| fadds                                             | Add single                         |  |
| Subtract:                                         |                                    |  |
| _fsubd                                            | Subtract double                    |  |
| _fsubs                                            | Subtract single                    |  |
| Multiply:                                         |                                    |  |
| _fmuld                                            | Multiply double                    |  |
| _fmuls                                            | Multiply single                    |  |
| Divide:                                           |                                    |  |
| _fdivd                                            | Divide double                      |  |
| fdivs                                             | Divide single                      |  |
| Negate:                                           |                                    |  |
| _fnegd                                            | Negate double                      |  |
| _fnegs                                            | Negate single                      |  |
| Logical Function Calls                            |                                    |  |
| Compare:                                          |                                    |  |
| _fcmpd                                            | Compare double                     |  |
| _fcmps                                            | Compare single                     |  |
| _fcmptd                                           | Compare with exception double      |  |
| _fcmpts                                           | Compare with exception single      |  |
| Check for NaNs:                                   |                                    |  |
| isnand                                            | Check for NaN double               |  |
| isnans                                            | Check for NaN single               |  |

### FPE Function Call Summary by Function

### FLOATING POINT SUPPORT

### FPE Function Call Summary by Mnemonic

| Table 10-6. FPE Function Call Summary by Mnemonic |                                    |  |
|---------------------------------------------------|------------------------------------|--|
| Mnemonic                                          | Name                               |  |
| _faddd                                            | Add double                         |  |
| fadds                                             | Add single                         |  |
| _fcmpd                                            | Compare double                     |  |
| _fcmps                                            | Compare single                     |  |
| _fcmptd                                           | Compare with exceptions double     |  |
| fcmpts                                            | Compare with exceptions single     |  |
| fdivd                                             | Divide double                      |  |
| _fdivs                                            | Divide single                      |  |
| fdtos                                             | Convert double to single           |  |
| fltod                                             | Convert integer to double          |  |
| _fltos                                            | Convert integer to single          |  |
| fmuld                                             | Multiply double                    |  |
| fmuls                                             | Multiply single                    |  |
| fnegd                                             | Negate double                      |  |
| _fnegs                                            | Negate single                      |  |
| _fstod                                            | Convert single to double           |  |
| _fsubd                                            | Subtract double                    |  |
| _fsubs                                            | Subtract single                    |  |
| _ftdtol                                           | Convert double to integer          |  |
| ftstol                                            | Convert single to integer          |  |
| _ftdtou                                           | Convert double to unsigned integer |  |
| _ftstou                                           | Convert single to unsigned integer |  |
| _futod                                            | Convert unsigned integer to double |  |
| _futos                                            | Convert unsigned integer to single |  |
| isnand                                            | Check for NaN double               |  |
| isnans                                            | Check for NaN single               |  |

### FPE Function Call Summary by Mnemonic

Appendix A WE 32100 Microprocessor Instruction Set

### APPENDIX A. WE 32100 MICROPROCESSOR INSTRUCTION SET

### CONTENTS

| A WE 13100 MICROPROCESSOR INSTRUCTION SET  |       |
|--------------------------------------------|-------|
| A. WE 32100 MICROPROCESSOR INSTRUCTION SET | 7-1   |
| A.I. NOIAHON                               | 4-1   |
| A.2 INSTRUCTION SET DESCRIPTIONS           | A-1   |
| A.3 INSTRUCTION SET SUMMARY BY FUNCTION    | 4-93  |
| A.4 INSTRUCTION SET SUMMARY BY MNEMONIC    | 4-99  |
| A.5 INSTRUCTION SET SUMMARY BY OPCODE      | Á-104 |
|                                            |       |

### A. WE 32100 MICROPROCESSOR INSTRUCTION SET LISTINGS

A.2 Instruction Set Descriptions presents descriptions of each member of the instruction set for the WE 32100 Microprocessor. The descriptions are in alphabetical order and any instructions that operate on more than one type of operand, byte, halfword, or word are listed on the same page (for quick reference to the instructions by function, mnemonic, or opcode see A.3 Instruction Set Summary by Function, A.4 Instruction Set Summary by Mnemonic, and A.5 Instruction Set Summary by Opcode).

### A.1 NOTATION

Each instruction description contains several parts: assembler syntax, opcode operation, address modes, condition flags, exceptions, examples, and notes (optional).

Assembler Syntax. Presents the assembly language syntax for the instruction, including any required spacing and punctuation. The user-specified elements appear in italics. All operands must appear in the order shown. If an instruction has byte, halfword, and word forms, all three forms are presented.

The syntax uses the following symbols to denote operands that may be written in the address modes shown in Table 5-2: *count, dst, offset, src, width.* Program control instructions use *disp8* or *disp16* as a displacement operand. This operand does not use an address mode, but is written as an 8- or 16-bit literal.

**Opcodes** – Lists each opcode with the appropriate mnemonic and function.

**Operation** - Describes the operation performed. The description generally uses C language syntax and the operators and symbols shown in Table A-1.

Address Modes – Identifies the valid address modes for each operand. Refer to Table 5-4 for address mode syntax and to Table A-2 for the syntax for referencing registers.

Condition Flags – Identifies the effect of the instruction on each of the condition flags.

**Exceptions** - Identifies any error conditions that may result in illegal operands, opcodes, or operations.

**Examples** – Presents examples of the instruction written in assembly language. In some cases, it will give the contents of registers before and after execution. Register bytes are read from right to left and their contents are given as hexadecimal values.

Notes (Optional) – Explains other parts of the description when necessary.

### A.2 INSTRUCTION SET DESCRIPTIONS

The instruction set is described in detail on the following pages.

# WE 32100 MICROPROCESSOR INSTRUCTION SET Notation

| T                                                     | able A-1. Assembly Language Operators and Symbols                     |
|-------------------------------------------------------|-----------------------------------------------------------------------|
| Symbol                                                | Description                                                           |
| *x                                                    | Indirection; value pointed to by x                                    |
| &x                                                    | Address of x                                                          |
| !x                                                    | Not x                                                                 |
| ++x                                                   | Increment x                                                           |
| x                                                     | Decrement x                                                           |
| $\sim X$                                              | Complement x                                                          |
| -x                                                    | Negate x; form two's complement of x                                  |
| x+y                                                   | Add y to x                                                            |
| x—y                                                   | Subtract y from x                                                     |
| x*y                                                   | Multiply x by y                                                       |
| x/y                                                   | Divide y into x                                                       |
| x%y                                                   | Modulo x and y (remainder of x/y)                                     |
| x&y                                                   | Bitwise AND x and y                                                   |
| xy                                                    | Bitwise inclusive OR x and y                                          |
| x∧y                                                   | Bitwise exclusive OR (XOR) x and y                                    |
| x< <y< td=""><td>Shift x to the left y bits</td></y<> | Shift x to the left y bits                                            |
| x>>y                                                  | Shift x to the right y bits                                           |
| x < y                                                 | x less than y                                                         |
| x>y                                                   | x greater than y                                                      |
| x==y                                                  | Equality; x equal to y                                                |
| x!=y                                                  | x not equal to y                                                      |
| =                                                     | Assigns the value on the right to the location identified on the left |
| AP                                                    | Argument pointer; register 10 (r10)                                   |
| count                                                 | Count operand                                                         |
| dst                                                   | Destination operand                                                   |
| FP                                                    | Frame pointer; register 9 (r9)                                        |
| PC                                                    | Program counter; register 15 (r15)                                    |
| PSW                                                   | Processor status word; register 11 (r11)                              |
| SEXT(x)                                               | Function that returns x, sign extended through 32 bits                |
| SP                                                    | Stack pointer; register 12 (r12)                                      |
| *(SP)                                                 | A pop from the stack; decrement SP by 4 before removing data ()       |
|                                                       | from the stack                                                        |
| *(SP++)                                               | A push onto the stack; store data and increment SP by 4               |
| src                                                   | Source operand                                                        |
| 0xn                                                   | Hexadecimal value where n is the digits 0 through 9 and a through     |
| ·                                                     | f (or A through F); may also be written 0Xn                           |
| /*comment*/                                           | A comment, not an operation                                           |
| {operation}                                           | An operation other than an instruction                                |

| Table A-2. Register Set |      |                     |                                             |
|-------------------------|------|---------------------|---------------------------------------------|
| Register                | Name | Assembler<br>Syntax | Assigned Function                           |
| 0                       | r0   | %r0                 | General-purpose (Note 1)                    |
| 1                       | r1   | %r1                 | General-purpose (Note 1)                    |
| 2                       | r2   | %r2                 | General-purpose (Note 1)                    |
| 3                       | r3   | %r3                 | General-purpose                             |
| 4                       | r4   | %r4                 | General-purpose                             |
| 5                       | r5   | %r5                 | General-purpose                             |
| 6                       | r6   | %r6                 | General-purpose                             |
| 7                       | r7   | %r7                 | General-purpose                             |
| 8                       | r8   | %r8                 | General-purpose                             |
| 9                       | FP   | %fp or %r9          | Frame pointer                               |
| 10                      | AP   | %ap or %r10         | Argument pointer                            |
| 11                      | PSW  | %psw or %r11        | Processor status word (Note 2)              |
| 12                      | SP   | %sp or %r12         | Stack pointer                               |
| 13                      | PCBP | %pcbp or %r13       | Processor control block<br>pointer (Note 2) |
| 14                      | ISP  | %isp or %r14        | Interrupt stack pointer (Note 2)            |
| 15                      | PC   | %pc or %r15         | Program counter (Note 3)                    |

Notes:

- 1. Block or string instructions may use this register as an implied argument for indexing or addressing. Operating system instructions also use these registers.
- 2. Privileged register. Writing to this register when the processor is not in kernel execution level causes a privileged-register exception.
- 3. Registers 11 and 15 may not be used in some address modes.

### ADDB2 ADDH2 ADDW2

### ADDB2 ADDH2 ADDW2

### ADD

| Assembler<br>Syntax | ADDB2src,dstAdd byteADDH2src,dstAdd halfwordADDW2src,dstAdd word                       |
|---------------------|----------------------------------------------------------------------------------------|
| Opcodes             | 0x9F ADDB2<br>0x9E ADDH2<br>0x9C ADDW2                                                 |
| Operation           | dst = dst + src                                                                        |
| Address             | src all modes                                                                          |
| Modes               | dst all modes except literal or immediate                                              |
| Condition<br>Flags  | N = 1, if $(dst + src) < 0$                                                            |
|                     | Z = 1, if $(dst + src) == 0$                                                           |
|                     | C = 1, if carry out of sign bit of dst                                                 |
|                     | V = 1, if overflow                                                                     |
| Exceptions          | Illegal operand exception occurs if literal or immediate mode is used for <i>dst</i> . |
|                     | Integer overflow exception occurs if there is truncation.                              |
| Examples            | ADDB2 \$0x100,%r0<br>ADDH2 %r0,%r3<br>ADDW2 4(%r3),*\$0x110                            |

### ADDB3 ADDH3 ADDW3

### ADDB3 ADDH3 ADDW3

### ADD, 3 Address

| Assembler          | ADDB3 src1, src2, dst Add byte, 3 address                                         |
|--------------------|-----------------------------------------------------------------------------------|
| Syntax             | ADDH3 src1, src2, dst Add halfword, 3 address                                     |
|                    | ADDW3 src1, src2, dst Add word, 3 address                                         |
|                    |                                                                                   |
| Opcodes            | 0xDF ADDB3                                                                        |
|                    | 0xDE ADDH3                                                                        |
|                    | 0xDC ADDw3                                                                        |
| Operation          | dst = src1 + src2                                                                 |
| Address<br>Modes   | src1 all modes                                                                    |
|                    | src2 all modes                                                                    |
|                    |                                                                                   |
|                    | dst all modes except literal or immediate                                         |
| Condition<br>Flags | N = 1,  if  (src1 + src2) < 0                                                     |
|                    | Z = 1, if $(src1 + src2) == 0$                                                    |
|                    | C = 1, if carry out of sign bit of dst                                            |
|                    | V = 1, if overflow                                                                |
| Exceptions         | Illegal operand exception occurs if literal or immediate mode is used for $dst$ . |
|                    | Integer overflow exception occurs if there is truncation.                         |
| Examples           | ADDB3 %r0,%r3,%r5                                                                 |
|                    | ADDH3 4(%r2),*\$0x110,%r3                                                         |
|                    | ADDW3 *\$0x1F0,4(%r1),%r0                                                         |
|                    |                                                                                   |

### ALSW3

**ARITHMETIC LEFT SHIFT** 

### ALSW3

#### Arithmetic left shift word ALSW3 count.src.dst Assembler **Syntax** 0xC0 ALSW3 Opcode $dst = src \ll (count \& 0x1F)$ bits Operation Address count all modes Modes all modes src all modes except literal or immediate dst N = 1, if dst < 0Condition Flags Z = 1, if dst == 0C = 0V = 0 (see Note) Exceptions Illegal operand exception occurs if literal or immediate mode is used for dst. Examples Before: 8F | 0F | DF | FD r0 -increasing bits ALSW3 &2,%r0,%r0 After: 3C | 3F 7F F4 r0 Note All operands are of type word. However, only the five low-order bits of

All operands are of type word. However, only the five low-order bits of count are used; the upper bits are ignored. No bits are shifted past the sign bit, so integer overflow cannot occur. However, the V bit can be set if an expanded-operand type mode changes the type of dst. Zeros replace bits that are shifted out. The sign bit is not changed.

### ANDB2 ANDH2 ANDW2

### ANDB2 ANDH2 ANDW2

### AND

| Assembler  | ANDB2 src, dst AND byte                                                           |
|------------|-----------------------------------------------------------------------------------|
| Syntax     | ANDH2 src,dst AND halfword<br>ANDW2 src,dst AND word                              |
| Opcodes    | 0xBB ANDB2<br>0xBA ANDH2<br>0xB8 ANDW2                                            |
| Operation  | dst = dst & src                                                                   |
| Address    | src all modes                                                                     |
| Modes      | dst all modes except literal or immediate                                         |
| Condition  | N = MSB of $dst$                                                                  |
| Flags      | Z = 1, if $dst == 0$                                                              |
|            | C = 0                                                                             |
|            | V = 1, if result must be truncated to fit dst size                                |
| Exceptions | Illegal operand exception occurs if literal or immediate mode is used for $dst$ . |
| Examples   | ANDB2 &7,6(%r1)                                                                   |
|            | ANDH2 %r0,*\$result<br>ANDW2 (%r1).%r4                                            |

### ANDB3 ANDH3 ANDW3

### AND, 3 ADDRESS

| Assembler<br>Syntax | ANDB3src1,src2,dstANDbyte, 3 addressANDH3src1,src2,dstANDhalfword, 3 addressANDW3src1,src2,dstANDword, 3 address |
|---------------------|------------------------------------------------------------------------------------------------------------------|
| Opcodes             | 0xFB ANDB3<br>0xFA ANDH3<br>0xF8 ANDW3                                                                           |
| Operation           | dst = src2 & src1                                                                                                |
| Address<br>Modes    | src1 all modes                                                                                                   |
|                     | src2 all modes                                                                                                   |
|                     | dst all modes except literal or immediate                                                                        |
| Condition           | N = MSB of $dst$                                                                                                 |
| Flags               | Z = 1, if $dst == 0$                                                                                             |
|                     | C = 0                                                                                                            |
|                     | V = 1, if result must be truncated to fit dst size                                                               |
| Exceptions          | Illegal operand exception occurs if literal or immediate mode is used for $dst$ .                                |
| Examples            | ANDB3 &0x27,*\$0x300,%r6<br>ANDH3 0x31(%r5),%r0,%r1<br>ANDW3 %r2,%r1,%r0                                         |





### **ARITHMETIC RIGHT SHIFT**

extension.

| Assembler<br>Syntax | ARSB3 count,src,dst Arithmetic right shift byte<br>ARSH3 count,src,dst Arithmetic right shift halfword<br>ARSW3 count,src,dst Arithmetic right shift word      |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Opcodes             | 0xC7 ARSB3<br>0xC6 ARSH3<br>0xC4 ARSW3                                                                                                                         |
| Operation           | dst = src >> (count & 0x1f) bits                                                                                                                               |
| Address             | count all modes                                                                                                                                                |
| lviodes             | src all modes                                                                                                                                                  |
|                     | dst all modes except literal or immediate                                                                                                                      |
| Condition           | N = 1, if $dst < 0$                                                                                                                                            |
| Flags               | Z = 1, if $dst == 0$                                                                                                                                           |
|                     | C = 0                                                                                                                                                          |
|                     | V = 0                                                                                                                                                          |
| Exceptions          | Illegal operand exception occurs if literal or immediate mode is used for $dst$ .                                                                              |
| Examples            | Before: r0 OF OF 77 AF                                                                                                                                         |
|                     | -increasing bits                                                                                                                                               |
|                     | ARSH3 &2,%r0,%r0                                                                                                                                               |
|                     | After: r0 00 00 1D EB                                                                                                                                          |
| Note                | All operands are of type word. However, only the five low-order bits of <i>count</i> are used; the upper bits are ignored. The sign bit (MSB) of <i>src</i> is |

copied as bits are shifted out. The type of src does not affect sign

BCCB BCCH

### BCCB BCCH

### **BRANCH ON CARRY CLEAR**

| Assembler<br>Syntax | BCCB disp8Branch on carry clear, byte displacementBCCH disp16Branch on carry clear, halfword displacement |
|---------------------|-----------------------------------------------------------------------------------------------------------|
| Opcodes             | 0x53 BCCB<br>0x52 BCCH                                                                                    |
| Operation           | if $(C == 0)$<br>PC = PC + SEXT( <i>disp</i> )                                                            |
| Address<br>Modes    | None valid<br>disp8 = signed 8-bit value                                                                  |
|                     | disp16 = signed 16-bit value                                                                              |
| Condition<br>Flags  | Unchanged                                                                                                 |
| Exceptions          | None                                                                                                      |
| Examples            | BCCB 0x9<br>BCCH 0xFF23                                                                                   |

, , <sup>,</sup>

BCSB BCSH

### **BRANCH ON CARRY SET**

| Assembler          | BCSB disp8 Branch on carry set, byte displacement      |
|--------------------|--------------------------------------------------------|
| Syntax             | BCSH disp16 Branch on carry set, halfword displacement |
| Opcodes            | 0x5B BCSB<br>0x5A BCSH                                 |
| Operation          | if $(C ==1)$<br>PC = PC + SEXT( <i>disp</i> )          |
| Address<br>Modes   | None valid<br>disp8 = signed 8-bit value               |
|                    | disp16 = signed 16-bit value                           |
| Condition<br>Flags | Unchanged                                              |
| Exceptions         | None                                                   |
| Examples           | BCSB 0xFF<br>BCSH 0x1234                               |

# **BRANCH ON EQUAL**

| Assembler          | BEB disp8 Branch on equal, byte displacement   |
|--------------------|------------------------------------------------|
| Syntax             | BEH disp16 Branch on equal, byte displacement  |
| Opcodes            | 0x7FBEB0x6FBEB0x7EBEH0x6EBEH                   |
| Operation          | if $(Z == 1)$<br>PC = PC + SEXT( <i>disp</i> ) |
| Address<br>Modes   | None valid<br>disp8 = signed 8-bit value       |
|                    | disp16 = signed 16-bit value                   |
| Condition<br>Flags | Unchanged                                      |
| Exceptions         | None                                           |
| Examples           | BEB 0xF1<br>BEH 0x4221                         |

BGB BGH

### **BRANCH ON GREATER THAN (SIGNED)**

| Assembler<br>Syntax | <ul> <li>BGB disp8 Branch on greater than, byte displacement (signed)</li> <li>BGH disp16 Branch on greater than, halfword displacement (signed)</li> </ul> |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Opcodes             | 0x47 BGB<br>0x46 BGH                                                                                                                                        |
| Operation           | if $((N \& Z) == 0)$<br>PC = PC + SEXT(disp)                                                                                                                |
| Address<br>Modes    | None valid<br>disp8 = signed 8-bit value<br>disp16 = signed 16-bit value                                                                                    |
| Condition<br>Flags  | Unchanged                                                                                                                                                   |
| Exceptions          | None                                                                                                                                                        |
| Examples            | BGB more<br>BGH less                                                                                                                                        |

### BGEB BGEH

# BRANCH ON GREATER THAN OR EQUAL (SIGNED)

| Assembler<br>Syntax | BGEB disp8Branch on greater than or equal, byte<br>displacement (signed)BGEH disp16Branch on greater than or equal, halfword<br>displacement (signed) |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Opcodes             | 0x43 BGEB<br>0x42 BGEH                                                                                                                                |
| Operation           | if $((N == 0) (Z == 1))$<br>PC = PC + SEXT( <i>disp</i> )                                                                                             |
| Address<br>Modes    | None valid<br>disp8 = signed 8-bit value<br>disp16 = signed 16-bit value                                                                              |
| Condition<br>Flags  | Unchanged                                                                                                                                             |
| Exceptions          | None                                                                                                                                                  |
| Examples            | BGEB again<br>BGEH 0xF102                                                                                                                             |

# BRANCH ON GREATER THAN OR EQUAL (UNSIGNED)

| Assembler<br>Syntax | BGEUB disp8Branch on greater than or equal, byte<br>displacement (unsigned)BGEUH disp16Branch on greater than or equal, halfword<br>displacement (unsigned) |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Opcodes             | 0x53 BGEUB<br>0x52 BGEUH                                                                                                                                    |
| Operation           | if $(C == 0)$<br>PC = PC + SEXT(disp)                                                                                                                       |
| Address<br>Modes    | None valid<br>disp8 = signed 8-bit value<br>disp16 = signed 16-bit value                                                                                    |
| Condition<br>Flags  | Unchanged                                                                                                                                                   |
| Exceptions          | None                                                                                                                                                        |
| Examples            | BGEUB 0xA1<br>BGEUH ahead                                                                                                                                   |

### **BRANCH ON GREATER THAN (UNSIGNED)**

| Assembler<br>Syntax | BGUB disp8 Branch on greater than, byte displacement (unsigned)      |
|---------------------|----------------------------------------------------------------------|
|                     | BGUH disp16 Branch on greater than, halfword displacement (unsigned) |
| Opcodes             | 0x57 BGUB<br>0x56 BGUH                                               |
| Operation           | if $((C \& Z) == 0)$<br>PC = PC + SEXT(disp)                         |
| Address<br>Modes    | None valid<br>disp8 = signed 8-bit value                             |
|                     | disp16 = signed 16-bit value                                         |
| Condition<br>Flags  | Unchanged                                                            |
| Exceptions          | None                                                                 |
| Examples            | BGUB 0xDE<br>BGUH 0xF123                                             |

### BITB BITH BITW

### BITB BITH BITW

### **BIT TEST**

| Assembler<br>Syntax | BITB src1,src2 Bit test byte<br>BITH src1,src2 Bit test halfword                                                                                          |
|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     | BITW src1, src2 Bit test word                                                                                                                             |
| Opcodes             | 0x3B BITB<br>0x3A BITH<br>0x38 BITW                                                                                                                       |
| Operation           | temp = src2 & src1                                                                                                                                        |
| Address<br>Modes    | src1 all modes                                                                                                                                            |
|                     | src2 all modes                                                                                                                                            |
| Condition<br>Flags  | N = MSB of temp                                                                                                                                           |
| ~ ~~~~              | Z = 1, if temp == 0                                                                                                                                       |
|                     | C = 0                                                                                                                                                     |
|                     | $\mathbf{V} = 0$                                                                                                                                          |
| Exceptions          | None                                                                                                                                                      |
| Examples            | BITB %r0,{uhalf}%r1<br>BITH *\$0xFF,%r3<br>BITW bit (%r3),(%r0)                                                                                           |
| Note                | The final value of temp, a temporary register, determines the setting of<br>the condition codes. Temp is discarded upon completion of the<br>instruction. |

A-17

r

# BRANCH ON LESS THAN (SIGNED)

| Assembler<br>Syntax | BLB disp8 Branch on less than, byte displacement (signed)      |
|---------------------|----------------------------------------------------------------|
|                     | BLH disp16 Branch on less than, halfword displacement (signed) |
| Opcodes             | 0x4B BLB<br>0x4A BLH                                           |
| Operation           | if $((N == 1) \& (Z == 0))$<br>PC = PC + SEXT( <i>disp</i> )   |
| Address<br>Modes    | None valid<br>disp8 = signed 8-bit value                       |
|                     | disp16 = signed 16-bit value                                   |
| Condition<br>Flags  | Unchanged                                                      |
| Exceptions          | None                                                           |
| Examples            | BLB 0x1F<br>BLH back                                           |
# BRANCH ON LESS THAN OR EQUAL (SIGNED)

| Assembler<br>Syntax | BLEB disp8Branch on less than or equal, byte displacement<br>(signed)BLEH disp16Branch on less than or equal, halfword<br>displacement (signed) |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| Opcodes             | 0x4F BLEB<br>0x4E BLEH                                                                                                                          |
| Operation           | if $((N Z) == 1)$<br>PC = PC + SEXT(disp)                                                                                                       |
| Address<br>Modes    | None valid<br>disp8 = signed 8-bit value                                                                                                        |
|                     | disp16 = signed 16-bit value                                                                                                                    |
| Condition<br>Flags  | Unchanged                                                                                                                                       |
| Exceptions          | None                                                                                                                                            |
| Examples            | BLEB 0x6<br>BLEH 0xFFF                                                                                                                          |

#### BLEUB BLEUH

# BRANCH ON LESS THAN OR EQUAL (UNSIGNED)

| Assembler<br>Syntax | BLEUB disp8Branch on less than or equal, byte<br>displacement (unsigned)BLEUH disp16Branch on less than or equal, halfword<br>displacement (unsigned) |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Opcodes             | 0x5F BLEUB<br>0x5E BLEUH                                                                                                                              |
| Operation           | if $((C Z) == 1)$<br>PC = PC + SEXT(disp)                                                                                                             |
| Address<br>Modes    | None valid<br>disp8 = signed 8-bit value<br>disp16 = signed 16-bit value                                                                              |
| Condition<br>Flags  | Unchanged                                                                                                                                             |
| Exceptions          | None                                                                                                                                                  |
| Examples            | BLEUB 0x14<br>BLEUH back                                                                                                                              |

## **BRANCH ON LESS THAN (UNSIGNED)**

| Assembler<br>Syntax | BLUB disp8 Branch on less than byte displacement (unsigned)      |
|---------------------|------------------------------------------------------------------|
|                     | BLUH disp16 Branch on less than halfword displacement (unsigned) |
| Opcodes             | 0x5B BLUB<br>0x5A BLUH                                           |
| Operation           | if $(C == 1)$<br>PC = PC + SEXT( <i>disp</i> )                   |
| Address<br>Modes    | None valid<br>disp8 = signed 8-bit value                         |
|                     | disp16 = signed 16-bit value                                     |
| Condition<br>Flags  | Unchanged                                                        |
| Exceptions          | None                                                             |
| Examples            | BLUB 0x12<br>BLUH 0xFF12                                         |

# **BRANCH ON NOT EQUAL**

| Assembler          | BNEB disp8 Branch on less than, byte displacement      |
|--------------------|--------------------------------------------------------|
| Syntax             | BNEH disp16 Branch on less than, halfword displacement |
|                    |                                                        |
| Opcodes            | 0x77 BNEB                                              |
| -                  | 0x67 BNEB                                              |
|                    | 0x76 BNEH                                              |
|                    | 0x66 BNEH                                              |
| Operation          | if $(Z == 0)$                                          |
| of a more          | PC = PC + SEXT(disp)                                   |
| Address            | None valid                                             |
| Modes              | disp8 = signed 8-bit value                             |
|                    |                                                        |
|                    | disp16 = signed 16-bit value                           |
| Condition<br>Flags | Unchanged                                              |
| Exceptions         | None                                                   |
| Examples           | BNEB 0xFE                                              |
|                    | BNEH 0xFF13                                            |
|                    |                                                        |

## BPT

## **BREAKPOINT TRAP**

| Assembler<br>Syntax | BPT Breakpoint trap                                                     |
|---------------------|-------------------------------------------------------------------------|
| Opcodes             | 0x2E BPT                                                                |
| Operation           | /*BPT executes the following processor operation*/<br>{breakpoint trap} |
| Address<br>Modes    | None                                                                    |
| Condition<br>Flags  | Unchanged                                                               |
| Exceptions          | Generates breakpoint trap exception.                                    |
| Examples            | BPT                                                                     |

.

#### BRB BRH

### BRANCH

| Assembler  | BRB disp8 Branch with byte displacement      |
|------------|----------------------------------------------|
| Syntax     | BRH disp16 Branch with halfword displacement |
|            |                                              |
| Opcodes    | 0x7B BRB                                     |
|            | 0x7A BRH                                     |
|            |                                              |
| Operation  | PC = PC + SEXT(disp)                         |
| A 33       | NT                                           |
| Address    | None valid                                   |
| iviodes    | alsp8 = signed 8-oft value                   |
|            | disp16 = signed 16-bit value                 |
| Condition  | Unchanged                                    |
| Flags      |                                              |
| Freentions | None                                         |
| Exceptions | INDIC                                        |
| Examples   | BRB 0xA                                      |
| -          | BRH 0xFAA                                    |
|            |                                              |

•

### **BRANCH TO SUBROUTINE**

| Assembler          | BSBB disp8 Branch to subroutine, byte displacement            |
|--------------------|---------------------------------------------------------------|
| Syntax             | BSBH disp16 Branch to subroutine, halfword displacement       |
| Opcodes            | 0x37 BSBB<br>0x36 BSBH                                        |
| Operation          | *(SP++) = address of next instruction<br>PC = PC + SEXT(disp) |
| Address<br>Modes   | None valid<br>disp8 = signed 8-bit value                      |
|                    | disp16 = signed 16-bit value                                  |
| Condition<br>Flags | Unchanged                                                     |
| Exceptions         | None                                                          |
| Examples           | BSBB sub2<br>BSBH sub1                                        |

#### BVCB BVCH

#### BVCB BVCH

### **BRANCH ON OVERFLOW CLEAR**

| Assembler<br>Syntax | BVCB disp8Branch to subroutine, byte displacementBVCH disp16Branch to subroutine, halfword displacement |
|---------------------|---------------------------------------------------------------------------------------------------------|
| Opcodes             | 0x63 BVCB<br>0x62 BVCH                                                                                  |
| Operation           | if $(V == 0)$<br>PC = PC + SEXT( <i>disp</i> )                                                          |
| Address<br>Modes    | None valid<br>disp8 = signed 8-bit value                                                                |
|                     | disp16 = signed 16-bit value                                                                            |
| Condition<br>Flags  | Unchanged                                                                                               |
| Exceptions          | None                                                                                                    |
| Examples            | BVCB 0x7E<br>BVCH 0x8F21                                                                                |

### **BRANCH ON OVERFLOW SET**

| Assembler          | BVSB disp8 Branch on overflow set, byte displacement      |
|--------------------|-----------------------------------------------------------|
| Syntax             | BVSH disp16 Branch on overflow set, haltword displacement |
| Opcodes            | 0x6B BVSB<br>0x6A BVSH                                    |
| Operation          | if $(V == 1)$<br>PC = PC + SEXT( <i>disp</i> )            |
| Address            | None valid                                                |
| iviodes            | aisp8 = signed 8-bit value                                |
|                    | disp16 = signed 16-bit value                              |
| Condition<br>Flags | Unchanged                                                 |
| Exceptions         | None                                                      |
| Examples           | BVS 0xF1<br>BVSB 0xFF77                                   |
|                    |                                                           |

CALL

## CALL PROCEDURE

| Assembler<br>Syntax | CALL src,dst Call procedure                                                                                                                                                                                                                                                                    |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Opcode              | 0x2C CALL                                                                                                                                                                                                                                                                                      |
| Operation           | tempa = $\&src$<br>tempb = $\&dst$<br>*(SP+4) = AP<br>*SP = address of next instruction<br>SP = SP+8<br>PC = tempb<br>AP = tempa                                                                                                                                                               |
| Address<br>Modes .  | <ul><li>src all modes except literal, register, or immediate</li><li>dst all modes except literal, register, or immediate</li></ul>                                                                                                                                                            |
| Condition<br>Flags  | Unchanged                                                                                                                                                                                                                                                                                      |
| Exceptions          | Illegal operand exception occurs if literal, register, expanded-operand type, or immediate mode is used for <i>src</i> or <i>dst</i> .                                                                                                                                                         |
| Examples            | CALL -(3*4) (%sp), func1 (see Figure 3-9)                                                                                                                                                                                                                                                      |
| Note                | Both operands are effective addresses. Temp is a temporary register.<br>CALL sets up the protocol for a C language function call. (Also see<br>Return from procedure.) CALL sets AP to first of the word arguments<br>that the calling function pushed on the stack before executing the call. |

## CFLUSH

.

## CFLUSH

## CACHE FLUSH

| Assembler<br>Syntax | CFLUSH Cache flush                                                                                                                    |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| Opcode              | 0x27 CFLUSH                                                                                                                           |
| Operation           | /*CFLUSH executes the following processor operation*/<br>{all entries in instruction cache are marked invalid}                        |
| Address<br>Modes    | None                                                                                                                                  |
| Condition<br>Flags  | Unchanged                                                                                                                             |
| Exceptions          | None                                                                                                                                  |
| Examples            | CFLUSH                                                                                                                                |
| Notes               | CFLUSH is a nonprivileged instruction.                                                                                                |
|                     | This instruction operates identically whether the instruction cache is enabled ( $PSW < CD > ==0$ ) or disabled ( $PWS < CD > ==1$ ). |

#### CLRB CLRH CLRW



### CLEAR

| Assembler<br>Syntax | CLRB dst Clear byte<br>CLRH dst Clear halfword<br>CLRW dst Clear word             |
|---------------------|-----------------------------------------------------------------------------------|
| Opcodes             | 0x83 CLRB<br>0x82 CLRH<br>0x80 CLRW                                               |
| Operation           | dst = 0                                                                           |
| Address<br>Modes    | dst all modes except literal or immediate                                         |
| Condition           | N = 0                                                                             |
| rlags               | Z = 1                                                                             |
|                     | C = 0                                                                             |
|                     | V = 0                                                                             |
| Exceptions          | Illegal operand exception occurs if literal or immediate mode is used for $dst$ . |
| Examples            | CLRB *&0x300<br>CLRH %r1<br>CLRW (%r0)                                            |

#### CMPB CMPH CMPW

,

#### CMPB CMPH CMPW

### COMPARE

| Assembler<br>Syntax | CMPB src1,src2Compare byteCMPH src1,src2Compare halfwordCMPW src1,src2Compare word                                                    |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| Opcodes             | 0x3F CMPB<br>0x3E CMPH<br>0x3C CMPW                                                                                                   |
| Operation           | temp = src2 - src1                                                                                                                    |
| Address             | src1 all modes                                                                                                                        |
| Wlodes              | src2 all modes                                                                                                                        |
| Condition           | N = 1, if $src2 < src1$ (signed)                                                                                                      |
| rlags               | Z = 1, if $src2 == src1$                                                                                                              |
|                     | C = 1, if $src2 < src1$ (unsigned)                                                                                                    |
|                     | V = 0                                                                                                                                 |
| Exceptions          | None                                                                                                                                  |
| Examples            | CMPB &10,%r0<br>CMPH (%r0),(%r1)<br>CMPW *\$0x12F7,%r2                                                                                |
| Note                | This instruction sets the condition flags N, Z, and C as if a subtract had been executed. Neither operand is altered (also see Test). |

A-31

#### DECB DECH DECW

DECB DECH DECW

### DECREMENT

| Assembler<br>Syntax | DECB dstDecrement byteDECH dstDecrement halfwordDECW dstDecrement word            |
|---------------------|-----------------------------------------------------------------------------------|
| Opcodes             | 0x97 DECB<br>0x96 DECH<br>0x94 DECW                                               |
| Operation           | dst = dst - 1                                                                     |
| Address<br>Modes    | dst all modes except literal or immediate                                         |
| Condition           | N = 1, if $(dst - 1) < 0$                                                         |
| Flags               | Z = 1, if $(dst - 1) = 0$                                                         |
|                     | C = 1, if borrow into sign bit of dst                                             |
|                     | V = 1, if overflow                                                                |
| Exceptions          | Illegal operand exception occurs if literal or immediate mode is used for $dst$ . |
|                     | Integer overflow exception occurs if there is truncation.                         |
| Examples            | DECB 4(%fp)<br>DECH \$result<br>DECW *\$last                                      |

#### DIVB2 DIVH2 DIVW2

#### DIVB2 DIVH2 DIVW2

Ų

### DIVIDE

| Assembler          | DIVB2 src,dst Divide byte                                                         |
|--------------------|-----------------------------------------------------------------------------------|
| Syntax             | DIVH2 src,dst Divide halfword                                                     |
|                    | DIVW2 src,dst Divide word                                                         |
| Opcodes            | 0xAF DIVB2                                                                        |
|                    | 0xAE DIVH2                                                                        |
|                    | 0xAC DIVW2                                                                        |
| Operation          | dst = dst / src                                                                   |
| Address<br>Modes   | src all modes                                                                     |
| IVAQUES            | dst all modes except literal or immediate                                         |
| Condition<br>Flags | N = 1, if $(dst / src) < 0$                                                       |
| r tags             | Z = 1, if (dst / src) == 0                                                        |
|                    | $\mathbf{C} = 0$                                                                  |
|                    | V = 1, if overflow                                                                |
| Exceptions         | Illegal operand exception occurs if literal or immediate mode is used for $dst$ . |
|                    | Integer zero-divide exception occurs if src is equal to 0.                        |
|                    | Integer overflow exception occurs if there is truncation.                         |
| Examples           | DIVB2 &40,%r6                                                                     |
|                    | DIVH2 4(%r3),(%r4)                                                                |
|                    | DIVW2 511rst. Slast                                                               |

### DIVB3 DIVH3 DIVW3

# **DIVIDE, 3 ADDRESS**

| Assembler          | DIVB3 src1, src2, dst Divide byte, 3 address                                           |
|--------------------|----------------------------------------------------------------------------------------|
| Syntax             | DIVH3 src1, src2, dst Divide halfword, 3 address                                       |
|                    | DIVW3 src1, src2, ast Divide word, 5 address                                           |
| Opcodes            | OxEF DIVB3                                                                             |
| •                  | OxEE DIVH3                                                                             |
|                    | UXEC DIVW3                                                                             |
| Operation          | dst = src2 / src1                                                                      |
| Address<br>Modes   | src1 all modes                                                                         |
|                    | src2 all modes                                                                         |
|                    | dst all modes except literal or immediate                                              |
| Condition<br>Flags | N = 1,  if  (src2 / src1) < 0                                                          |
| L'IAZ3             | Z = 1, if $(src2 / src1) == 0$                                                         |
|                    | C = 0                                                                                  |
|                    | V = 1, if overflow                                                                     |
| Exceptions         | Illegal operand exception occurs if literal or immediate mode is used for <i>dst</i> . |
|                    | Integer zero-divide exception occurs if src1 is equal to 0.                            |
|                    | Integer overflow exception occurs if there is truncation.                              |
| Examples           | DIVB3 &0x30,%r3,12(%ap)                                                                |
|                    | DIVH3 & $0x3030,(\%r2),5(\%r2)$                                                        |
|                    | DIVW3 & $0x304050,(\%r1),4(\%r1)$                                                      |

ţ

#### EXTFB EXTFH EXTFW



#### **EXTRACT FIELD**

| Assembler          | EXTFB width, offset, src, dst Extract field from byte                                                                |
|--------------------|----------------------------------------------------------------------------------------------------------------------|
| Syntax             | EXTFH width, offset, src, dst Extract field from halfword                                                            |
|                    | EXTFW width, offset, src, dst Extract field from word                                                                |
| Opcodes            | 0xCF EXTFB                                                                                                           |
|                    | 0xCC EXTFW                                                                                                           |
| Operation          | dst = FIELD(offset,width,src)                                                                                        |
| Address<br>Modes   | <i>width</i> all modes <i>offset</i> all modes <i>src</i> all modes <i>dst</i> all modes except literal or immediate |
| Condition<br>Flags | N = high-order bit of $dst Z = 1$ , if $dst == 0 C = 0$<br>V = 0 (see Note)                                          |
| Exceptions         | Illegal operand exception occurs if literal or immediate mode is used for $dst$ .                                    |
| Examples           | Before: Location $L1 = 0x01234567$                                                                                   |
|                    | EXTFW &10,&4,L1,%r0                                                                                                  |
|                    | After: r0 00 00 04 56                                                                                                |
|                    | = increasing bits                                                                                                    |

The field extracted starts at bit 4 of location L1, skips bits 0 through 3, and extends through bit 14 of L1. These eleven bits are written to bits 0 through 10 of r0; zeros fill the remaining bits of r0.

Note

Only the low-order five bits of width and offset are examined. If the sum width plus offset is greater than 32 (bits), then the field wraps around through bit 0 of the base word. The field specified by width, offset, and src is stored, right adjusted, in dst. The remaining bits of dst are set to 0. If the field is too large for the size of dst, the excess high-order bits are discarded and the V flag is set.

### EXTOP

## EXTOP

### EXTENDED OPCODE

| EXTOP byte Extended opcode                                                                                                                                                                                                                                                                  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x14 EXTOP                                                                                                                                                                                                                                                                                  |
| /*EXTOP executes the following processor operation*/<br>{reserved-opcode exception}                                                                                                                                                                                                         |
| None valid<br>byte = 8-bit value                                                                                                                                                                                                                                                            |
| Unchanged                                                                                                                                                                                                                                                                                   |
| Generates reserved opcode exception. See Note.                                                                                                                                                                                                                                              |
| EXTOP 0x2F                                                                                                                                                                                                                                                                                  |
| The EXTOP opcode is an escape to form additional instructions. The processor does not access <i>byte</i> when executing this instruction. Instead, it generates a reserved-opcode exception after decoding the opcode. The operating system's exception handler should access <i>byte</i> . |
|                                                                                                                                                                                                                                                                                             |

#### INCB INCH INCW

#### INCB INCH INCW

### INCREMENT

| Assembler<br>Syntax | INCB dstIncrement byteINCH dstIncrement halfwordINCW dstIncrement word            |
|---------------------|-----------------------------------------------------------------------------------|
| Opcodes             | 0x93 INCB<br>0x92 INCH<br>0x90 INCW                                               |
| Operation           | dst = dst + 1                                                                     |
| Address<br>Modes    | dst all modes except literal or immediate                                         |
| Condition           | N = 1, if $(dst + 1) < 0$                                                         |
| Flags               | Z = 1, if $(dst + 1)' == 0$                                                       |
|                     | C = 1, if carry into sign bit of dst                                              |
|                     | V = 1, if overflow                                                                |
| Exceptions          | Illegal operand exception occurs if literal or immediate mode is used for $dst$ . |
|                     | Integer overflow exception occurs if truncation takes place.                      |
| Examples            | INCB 4(%r2)<br>INCH %r0<br>INCW (%r1)                                             |

#### INSFB INSFH INSFW



### **INSERT FIELD**

| Assembler        | INSFB width, offset, src, dst Insert field from byte                                                                                                                                                                                                                                                                                                                                                                                  |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax           | INSFH width, offset, src, dst Insert field from halfword                                                                                                                                                                                                                                                                                                                                                                              |
|                  | INSFW width,offset,src,ast Insert field from word                                                                                                                                                                                                                                                                                                                                                                                     |
| Opcodes          | OxCB INSFB                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                  | 0xC8 INSFW                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Operation        | FIELD(offset, width, dst) = src                                                                                                                                                                                                                                                                                                                                                                                                       |
| Address<br>Modes | width all modes offset all modes src all modes dst all modes except literal or immediate                                                                                                                                                                                                                                                                                                                                              |
| Condition        | N = bit 31 of $dst Z = 1$ , if $dst == 0 C = 0 V = 0$ (see Note)                                                                                                                                                                                                                                                                                                                                                                      |
| Exceptions       | Illegal operand exception occurs if literal or immediate mode is used for <i>dst</i> .                                                                                                                                                                                                                                                                                                                                                |
| Examples         | Before: r0 AB CD EF 01                                                                                                                                                                                                                                                                                                                                                                                                                |
|                  | r1 00 00 05 67                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                  | = increasing bits                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                  | INSFW &11,&8,%r1,%r0                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                  | After: r0 AB C5 67 01                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                  | The field insertion starts at bit 8 of r0, skips bits 0 through 7, and extends through bit 19. Therefore, bits 8 through 19 of r0 now contain the same value as bits 0 through 11 of r1.                                                                                                                                                                                                                                              |
| Note             | Only the low-order five bits of width and offset are examined. If the sum width plus offset is greater than 32 (bits), the field wraps around to bit 0 of the destination. Starting with bit 0 of src, (width+1) bits are placed into dst beginning at the bit designated by offset. If dst is a byte or halfword and (width+offset) specifies a field that extends beyond dst, no bits beyond dst are altered but the V flag is set. |

## JMP

## JUMP

| Assembler<br>Syntax | JMP dst Jump                                                                                                                                         |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| Opcode              | 0x24 JMP                                                                                                                                             |
| Operation           | PC = &dst                                                                                                                                            |
| Address<br>Modes    | dst all modes except literal, register, or immediate                                                                                                 |
| Condition<br>Flags  | Unchanged                                                                                                                                            |
| Exceptions          | Illegal operand exception occurs if literal or immediate mode is used for $dst$ .                                                                    |
| Examples            | JMP .L12                                                                                                                                             |
| Note                | The operand $dst$ is an effective address; i.e., the 32-bit address of $dst$ is used as the destination rather than the word stored at that address. |

**JSB** 

### JUMP TO SUBROUTINE

| Assembler<br>Syntax | JSB dst Jump to subroutine                                                                                                                    |
|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| Opcode              | 0x34 JSB                                                                                                                                      |
| Operation           | *(SP++) = address of next instruction<br>PC = $\&dst$                                                                                         |
| Address<br>Modes    | dst all modes except literal, register, or immediate                                                                                          |
| Condition<br>Flags  | Unchanged                                                                                                                                     |
| Exceptions          | Illegal operand exception occurs if literal, expanded-operand type, or immediate mode is used for $dst$ .                                     |
| Examples            | JSB error                                                                                                                                     |
| Note                | The operand $dst$ is an effective address; i.e., the 32-bit address of $dst$ is used as the destination rather than the word at that address. |

#### LLSB3 LLSH3 LLSW3

## LOGICAL LEFT SHIFT

| Assembler<br>Syntax | LLSB3 count, src, dst Logical left shift byte                                                                                                                     |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symax               | LLSW3 count, src, dst Logical left shift word                                                                                                                     |
| Opcodes             | 0xD3 LLSB3<br>0xD2 LLSH3<br>0xD0 LLSW3                                                                                                                            |
| Operation           | dst = src << (count & 0x1F) bits                                                                                                                                  |
| Address<br>Modes    | count all modes                                                                                                                                                   |
|                     | src all modes                                                                                                                                                     |
|                     | dst all modes except literal or immediate                                                                                                                         |
| Condition           | N = MSB of $dst$                                                                                                                                                  |
| riags               | Z = 1, if $dst == 0$                                                                                                                                              |
|                     | C = 0                                                                                                                                                             |
|                     | V = 0, if result must be truncated to fit dst size                                                                                                                |
| Exceptions          | Illegal operand exception occurs if literal or immediate mode is used for $dst$ .                                                                                 |
| Examples            | Before: r0 OF OF DF FD                                                                                                                                            |
|                     | = increasing bits                                                                                                                                                 |
|                     | LLSH3 &2,%r0,%r0                                                                                                                                                  |
|                     | After: r0 FF FF 7F F4                                                                                                                                             |
| Note                | Only the five low-order bits of <i>count</i> are used; the high-order bits are ignored. Zeros replace the bits shifted out of the low-order bit position (bit 0). |

### LRSW3

### LRSW3

### LOGICAL RIGHT SHIFT

| Assembler<br>Syntax | LRSW3 count, src, dst Logical right shift word                                    |
|---------------------|-----------------------------------------------------------------------------------|
| Opcode              | 0xD4 LRSW3                                                                        |
| Operation           | dst = src >> (count & 0x1F) bits                                                  |
| Address             | count all modes                                                                   |
| lvlodes             | src all modes                                                                     |
|                     | dst all modes except literal or immediate                                         |
| Condition           | N = MSB  of  dst                                                                  |
| Flags               | Z = 1, if $dst == 0$                                                              |
|                     | C = 0                                                                             |
|                     | V = 1, if result must be truncated to fit dst size                                |
| Exceptions          | Illegal operand exception occurs if literal or immediate mode is used for $dst$ . |
| Examples            | Before: r0 C3 C0 00 00                                                            |
|                     | = increasing bits                                                                 |
|                     | LRSW3 &0x11,%r0,%r0                                                               |
|                     | After: r0 00 00 61 E0                                                             |
| Note                | All operands are type word. However, only the five low-order bits of              |

Note

All operands are type word. However, only the five low-order bits of *count* are used; the high-order bits are ignored. Zeros replace the bits shifted out of the high-order bit position (bit 31).





## **MOVE COMPLEMENTED**

| Assembler        | MCOMB src, dst Move complemented byte                                         |  |  |
|------------------|-------------------------------------------------------------------------------|--|--|
| Syntax           | MCOMH src, dst Move complemented halfword                                     |  |  |
|                  | MCOMW src,asi Move complemented word                                          |  |  |
| Opcodes          | 0x8B MCOMB<br>0x8A MCOMH<br>0x88 MCOMW                                        |  |  |
| Operation        | dst = -src                                                                    |  |  |
| Address<br>Modes | src all modes                                                                 |  |  |
| IVLOUES          | dst all modes except literal or immediate                                     |  |  |
| Condition        | N = MSB  of  dst                                                              |  |  |
| Flags            | Z = 1, if $dst == 0$                                                          |  |  |
|                  | C = 0                                                                         |  |  |
|                  | V = 1, if result must be truncated to fit dst size                            |  |  |
| Exceptions       | Illegal operand exception occurs if literal or immediate mode is used $dst$ . |  |  |
| Examples         | Before: r0 12 34 56 78                                                        |  |  |
|                  | = increasing bits                                                             |  |  |
|                  | MCOMW %r0,%r1                                                                 |  |  |
|                  | After: r1 ED CB A9 87                                                         |  |  |
| Note             | dst is the one's complement of src                                            |  |  |

.

for



#### MNEGB MNEGH MNEGW

### **MOVE NEGATED**

| Assembler<br>Syntax | MNEGB src,dstMove negated byteMNEGH src,dstMove negated halfwordMNEGW src,dstMove negated word |  |  |  |  |
|---------------------|------------------------------------------------------------------------------------------------|--|--|--|--|
| Opcodes             | 0x8F MNEGB<br>0x8E MNEGH<br>0x8C MNEGW                                                         |  |  |  |  |
| Operation           | dst = -src                                                                                     |  |  |  |  |
| Address             | src all modes                                                                                  |  |  |  |  |
| TATORES             | dst all modes except literal or immediate                                                      |  |  |  |  |
| Condition           | N = MSB of $dst$                                                                               |  |  |  |  |
| r lago              | Z = 1, if $dst == 0$                                                                           |  |  |  |  |
|                     | $\mathbf{C} = 0$                                                                               |  |  |  |  |
|                     | V = 1, if integer overflow                                                                     |  |  |  |  |
| Exceptions          | Illegal operand exception occurs if literal or immediate mode is used for $dst$ .              |  |  |  |  |
| Examples            | Before: r0 01 23 45 67                                                                         |  |  |  |  |
|                     | = increasing bits                                                                              |  |  |  |  |
|                     | MNEGB %r0,%r1                                                                                  |  |  |  |  |
|                     | After: r1 FF FF FF 99                                                                          |  |  |  |  |
| Note                | dst is the two's complement of src.                                                            |  |  |  |  |

.

#### MODB2 MODH2 MODW2

#### MODB2 MODH2 MODW2

## MODULO

| Assembler          | MODB2 src,dst Modulo byte                                                         |  |  |
|--------------------|-----------------------------------------------------------------------------------|--|--|
| Syntax             | MODH2 src, dst Modulo halfword                                                    |  |  |
|                    | MODW2 src,dst Modulo word                                                         |  |  |
| Opcodes            | 0xA7 MODB2<br>0xA6 MODH2<br>0xA4 MODW2                                            |  |  |
| Operation          | dst = dst % src                                                                   |  |  |
| Address<br>Modes   | src all modes                                                                     |  |  |
| IVAUUCS            | dst all modes except literal or immediate                                         |  |  |
| Condition<br>Flags | N = 1, if (dst % src) < 0                                                         |  |  |
|                    | $Z = 1$ , if $(dst \ \% \ src) == 0$                                              |  |  |
|                    | C = 0                                                                             |  |  |
|                    | V = 1, if overflow                                                                |  |  |
| Exceptions         | Illegal operand exception occurs if literal or immediate mode is used for $dst$ . |  |  |
|                    | Integer zero-divide exception occurs if src is equal to 0.                        |  |  |
|                    | Integer overflow exception occurs if there is truncation.                         |  |  |
| Examples           | MODB2 & $40,\%r3$                                                                 |  |  |
|                    | MODW2  \$\$ \$\$ \$\$ \$\$ \$\$ \$\$ \$\$ \$\$ \$\$ \$\$ \$\$ \$\$ \$\$           |  |  |
|                    |                                                                                   |  |  |

#### MODB3 MODH3 MODW3

#### MODB3 MODH3 MODW3

# **MODULO, 3 ADDRESS**

| Assembler  | MODB3 src1, src2, dst Modulo byte, 3 address                                      |  |  |  |  |
|------------|-----------------------------------------------------------------------------------|--|--|--|--|
| Syntax     | MODH3 src1, src2, dst Modulo halfword, 3 address                                  |  |  |  |  |
|            | MODW3 src1, src2, dst Modulo word, 3 address                                      |  |  |  |  |
| Opcodes    | 0xE7 MODB3<br>0xE6 MODH3<br>0xE4 MODW3                                            |  |  |  |  |
| Operation  | $dst = src2 \ \% \ src1$                                                          |  |  |  |  |
| Address    | src1 all modes                                                                    |  |  |  |  |
| Wodes      | src2 all modes                                                                    |  |  |  |  |
|            | dst all modes except literal or immediate                                         |  |  |  |  |
| Condition  | N = 1, if (src2 % src1) < 0                                                       |  |  |  |  |
| Flags      | Z = 1, if $(src2 % src1) == 0$                                                    |  |  |  |  |
|            | C = 0                                                                             |  |  |  |  |
|            | V = 1, if overflow                                                                |  |  |  |  |
| Exceptions | Illegal operand exception occurs if literal or immediate mode is used for $dst$ . |  |  |  |  |
|            | Integer zero-divide exception occurs if src1 is equal to 0.                       |  |  |  |  |
|            | Integer overflow exception occurs if there is truncation.                         |  |  |  |  |
| Examples   | MODB3 &40,%r3,0x1101(%r2)<br>MODH3 %r3,\$real,%r3<br>MODW3 4(%r2) *\$0x34 %r0     |  |  |  |  |
|            |                                                                                   |  |  |  |  |

#### MOVB MOVH MOVW

#### MOVB MOVH MOVW

### MOVE

| Assembler<br>Syntax         | MOVBsrc,dstMove byteMOVHsrc,dstMove halfwordMOVWsrc,dstMove word                                     |  |  |
|-----------------------------|------------------------------------------------------------------------------------------------------|--|--|
| Opcodes                     | 0x87 MOVB<br>0x86 MOVH<br>0x84 MOVW                                                                  |  |  |
| Operation                   | dst = src                                                                                            |  |  |
| Address                     | src all modes dst all modes except literal or immediate                                              |  |  |
| Modes<br>Condition<br>Flags | N = MSB of $dst Z = 1$ , if $dst == 0 C = 0$<br>V = 1, if result must be truncated to fit $dst$ size |  |  |
|                             | See Note                                                                                             |  |  |
| Exceptions                  | Illegal operand exception occurs if literal or immediate mode is used for $dst$ .                    |  |  |
| Examples                    | Before: r0 01 23 45 67                                                                               |  |  |
|                             | r1 AB AB AB AB                                                                                       |  |  |
|                             | =increasing bits                                                                                     |  |  |
|                             | MOVŴ %r0,%r1                                                                                         |  |  |
| Ϋ́ι.                        | After: r0 01 23 45 67                                                                                |  |  |
|                             | r1 01 23 45 67                                                                                       |  |  |
|                             | NZCV = 0000                                                                                          |  |  |



NOTES

If the expanded-type mode is used for *dst* or for both operands, this instruction can convert data from one type to another. The *src* operand determines the type of extension performed: if *src* is signed byte or halfword, sign extension occurs; if *src* is byte or unsigned halfword, zero extension occurs.

Use the following instructions for conversions if the destination is not a register.

#### Instruction

#### Conversion

| MOVB {sbyte}src,{shalf}dst | Signed byte to signed halfword   |
|----------------------------|----------------------------------|
| MOVB {sbyte}src,{sword}dst | Signed byte to signed word       |
| MOVH src,{sword}dst        | Byte to signed word              |
| MOVB src,{shalf}dst        | Byte to signed halfword          |
| MOVB src,{sword}dst        | Byte to signed word              |
| MOVH {uhalf}src,{sword}dst | Unsigned halfword to signed word |
| MOVH src,{sbyte}dst        | Halfword to signed byte          |
| MOVW src,{sbyte}dst        | Word to signed byte              |
| MOVW src,{shalf}dst        | Word to signed halfword          |
|                            |                                  |

If the destination is a register, use the following instructions for conversions:

| Instruction                                                                              | Conversion                       |
|------------------------------------------------------------------------------------------|----------------------------------|
| ANDH3 &0xff, <i>src</i> ,{byte} <i>dst</i><br>ANDW3 &0xff, <i>src</i> ,{byte} <i>dst</i> | Halfword to byte<br>Word to byte |
| MOVW src.dst; MOVH dst.dst                                                               | Word to halfword                 |

The instructions 'MOVW -,%psw' and 'MOVW %psw,-' do not change the condition flags.

### MOVAW

## MOVAW

### **MOVE ADDRESS (WORD)**

| Assembler<br>Syntax | MOVAW src,dst Move address (word)                                                                                                                          |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Opcode              | 0x04 MOVAW                                                                                                                                                 |
| Operation           | dst = &src                                                                                                                                                 |
| Address             | src all modes except literal, register, or immediate                                                                                                       |
| iviodes             | dst all modes except literal or immediate                                                                                                                  |
| Condition           | N = MSB  of  dst                                                                                                                                           |
| Flags               | Z = 1, if $dst == 0$                                                                                                                                       |
|                     | C = 0                                                                                                                                                      |
|                     | V = 0                                                                                                                                                      |
| Exceptions          | Illegal operand exception occurs if literal, register, or immediate mode is used for <i>src</i> , or if literal or immediate mode is used for <i>dst</i> . |
| Examples            | Before: r0 00 00 10 10                                                                                                                                     |
|                     | rl AB AB AB AB                                                                                                                                             |
|                     | = increasing bits                                                                                                                                          |
|                     | MOVAW 4(%r0),%r1                                                                                                                                           |
|                     | After: r1 00 00 10 14                                                                                                                                      |
| Noto                | Source operand type is offective address                                                                                                                   |

Note

Source operand type is effective address.

#### **MOVBLW**

#### **MOVBLW**

#### **MOVE BLOCK**

| Assembler<br>Syntax | MOVBLW Move block of words                                                                                                        |  |
|---------------------|-----------------------------------------------------------------------------------------------------------------------------------|--|
| Opcode              | 0x3019 MOVBLW                                                                                                                     |  |
| Operation           | <pre>while (R2 &gt; 0) {     *R1 = *R0;     {disable interrupts}    R2;     R0=R0+4;     R1=R1+4;     {enable interrupts} }</pre> |  |
| Address<br>Modes    | None                                                                                                                              |  |
| Condition<br>Flags  | Unchanged                                                                                                                         |  |
| Exceptions          | External memory fault may occur in the middle of an iteration.                                                                    |  |
| Examples            | Before: r0 00 00 01 00<br>r1 00 00 02 00                                                                                          |  |
|                     | r2 00 00 00 03                                                                                                                    |  |

=increasing bits

Assume three word locations starting at 0x100 contain the word values 0x5, 0x10 and 0x20, respectively.

#### MOVBLW

| After: | r0 | 00 | 00 | 01 | 0C |  |
|--------|----|----|----|----|----|--|
|        | r1 | 00 | 00 | 02 | 0C |  |
|        | r2 | 00 | 00 | 00 | 00 |  |

#### MOVBLW

Three word locations starting at 0x200 now also contain 0x5, 0x10 and 0x20, respectively.

Notes

Opcode occupies 16 bits. All operands are implicitly defined in the registers (r0, r1, and r2) and are 32-bit words. These registers must be preset with the following information before executing MOVBLW:

- r0 Address of source
- r1 Address of destination
- r2 Number of words to be moved.

The instruction may be interrupted *only* at the end of an iteration. A memory fault may occur in the middle of an iteration. To restart the instruction after a fault, execute MOVBLW again; the registers are updated after the only memory access that could cause the fault. At each iteration, r0 and r1 are incremented by 4, and r2 is decremented by 1. Execution of MOVBLW is finished when r2 is 0.

#### MULB2 MULH2 MULW2

#### MULB2 MULH2 MULW2

### MULTIPLY

| Assembler<br>Syntax | MULB2src,dstMultiply byteMULH2src,dstMultiply halfwordMULW2src,dstMultiply word   |  |  |  |  |
|---------------------|-----------------------------------------------------------------------------------|--|--|--|--|
| Opcodes             | 0xAB MULB2<br>0xAA MULH2<br>0xA8 MULW2                                            |  |  |  |  |
| Operation           | dst = dst * src                                                                   |  |  |  |  |
| Address             | src all modes                                                                     |  |  |  |  |
| IVIODES             | dst all modes except literal or immediate                                         |  |  |  |  |
| Condition           | N = 1, if $(dst * src) < 0$                                                       |  |  |  |  |
| Flags               | Z = 1, if $(dst * src) == 0$                                                      |  |  |  |  |
|                     | C = 0                                                                             |  |  |  |  |
|                     | V = 1, if overflow                                                                |  |  |  |  |
| Exceptions          | Illegal operand exception occurs if literal or immediate mode is used for $dst$ . |  |  |  |  |
|                     | Integer overflow exception occurs if there is truncation.                         |  |  |  |  |
| Example             | MULBH2 %r2,{sbyte}4(%r6)                                                          |  |  |  |  |

.

# **MULTIPLY, 3 ADDRESS**

| Assembler  | MULB3 src1, src2, dst Multiply byte, 3 address                                    |  |  |  |  |
|------------|-----------------------------------------------------------------------------------|--|--|--|--|
| Syntax     | MULH3 src1, src2, dst Multiply halfword, 3 address                                |  |  |  |  |
|            | MULW3 src1, src2, dst Multiply word, 3 address                                    |  |  |  |  |
|            |                                                                                   |  |  |  |  |
| Opcodes    | OXEB MULB3                                                                        |  |  |  |  |
|            | UXEA MULH3                                                                        |  |  |  |  |
|            | UXE8 MOLWJ                                                                        |  |  |  |  |
| Operation  | dst = src1 * src2                                                                 |  |  |  |  |
| Address    | src1 all modes                                                                    |  |  |  |  |
| Modes      | STUL AIL HIGHES                                                                   |  |  |  |  |
|            | src2 all modes                                                                    |  |  |  |  |
|            | dst all modes except literal or immediate                                         |  |  |  |  |
| Condition  | N = 1, if ( <i>src1</i> * <i>src2</i> ) < 0                                       |  |  |  |  |
| Flags      | Z = 1, if (src1 * src2) == 0                                                      |  |  |  |  |
|            | C = 0                                                                             |  |  |  |  |
|            | V = 1, if overflow                                                                |  |  |  |  |
| Exceptions | Illegal operand exception occurs if literal or immediate mode is used for $dst$ . |  |  |  |  |
| 7          | Integer overflow exception occurs if there is truncation.                         |  |  |  |  |
| Examples   | MULH3 %r3,*\$0x1004,%r4                                                           |  |  |  |  |

### **MVERNO**

### **MVERNO**

#### **MOVE VERSION NUMBER**

| Assembler<br>Syntax | MVERNO Move processor version number                                                                          |  |
|---------------------|---------------------------------------------------------------------------------------------------------------|--|
| Opcode              | 0x3009 MVERNO                                                                                                 |  |
| Operation           | r0 = processor version number                                                                                 |  |
| Address<br>Modes    | None                                                                                                          |  |
| Condition<br>Flags  | Unchanged                                                                                                     |  |
| Exceptions          | None                                                                                                          |  |
| Example             | MVERNO                                                                                                        |  |
| Note                | Opcode occupies 16 bits. Version number is the version of the processor and may range from $-128$ to $+127$ . |  |
NOP NOP2 NOP3

### **NO OPERATION**

| Assembler                             | NOP No operation, 1 byte                                             |
|---------------------------------------|----------------------------------------------------------------------|
| Syntax                                | NOP2 No operation, 2 bytes                                           |
|                                       | NOP3 No operation, 3 bytes                                           |
|                                       |                                                                      |
| Opcodes                               | 0x70 NOP                                                             |
| А                                     | 0x73 NOP2                                                            |
|                                       | 0x72 NOP3                                                            |
| Operation                             | None                                                                 |
|                                       |                                                                      |
| Address                               | None                                                                 |
| Modes                                 |                                                                      |
| Condition                             | Unchanged                                                            |
| Flags                                 |                                                                      |
| Exceptions                            | None                                                                 |
| A A A A A A A A A A A A A A A A A A A |                                                                      |
| Examples                              | NOP                                                                  |
| *                                     | NOP2                                                                 |
|                                       | NOP3                                                                 |
| Notes                                 | The assembler inserts a NOP before instructions (other than branch)  |
|                                       | that read the PSW. This NOP allows the conditions bits to stabilize. |
|                                       | The bytes following NOP2 and NOP3 are generated by the assembler     |
|                                       | and are ignored by the processor. They may be any value.             |
|                                       |                                                                      |

#### ORB2 ORH2 ORW2

#### ORB2 ORH2 ORW2

### OR

| Assembler<br>Syntax | ORB2 src,dst OR byte<br>ORH2 src,dst OR halfword<br>ORW2 src,dst OR word               |
|---------------------|----------------------------------------------------------------------------------------|
| Opcodes             | 0xB3 ORB2<br>0xB2 ORH2<br>0xB0 ORW2                                                    |
| Operation           | dst = dst src                                                                          |
| Address<br>Modes    | src all modes                                                                          |
|                     | dst all modes except literal or immediate                                              |
| Condition<br>Flags  | N = MSB of $dst$                                                                       |
|                     | Z = 1, if $dst == 0$                                                                   |
|                     | C = 0                                                                                  |
|                     | V = 1, if result must be truncated to fit dst size                                     |
| Exceptions          | Illegal operand exception occurs if literal or immediate mode is used for <i>dst</i> . |
| Examples            | ORB2 &12,4(%fp)<br>ORH2 %r0,4(%r0)<br>ORW2 %r3,\$result                                |

ORB3 ORH3 ORW3

#### ORB3 ORH3 ORW3

## **OR, 3 ADDRESS**

| Assembler<br>Syntax | ORB3src1,src2,dstORbyte, 3 addressORH3src1,src2,dstORhalfword, 3 addressORW3src1,src2,dstORword, 3 address |
|---------------------|------------------------------------------------------------------------------------------------------------|
| Opcodes             | 0xF3 ORB3<br>0xF2 ORH3<br>0xF0 ORW3                                                                        |
| Operation           | dst = src2 src1                                                                                            |
| Address             | src1 all modes                                                                                             |
| Modes               | src2 all modes                                                                                             |
|                     | dst all modes except literal or immediate                                                                  |
| Condition<br>Flags  | N = MSB  of  dst                                                                                           |
|                     | Z = 1, if $dst == 0$                                                                                       |
|                     | C = 0                                                                                                      |
|                     | V = 1, if result must be truncated to fit <i>dst</i> size                                                  |
| Exceptions          | Illegal operand exception occurs if literal or immediate mode is used for $dst$ .                          |
| Examples            | ORB3 &16,*\$0x304,%r0<br>ORH3 %r1,4(%r1),%r1<br>ORW3 %r2,%r3,%r1                                           |

## POPW

## POPW

## POP (WORD)

| Assembler<br>Syntax | POPW dst Pop (word)                                                                                       |
|---------------------|-----------------------------------------------------------------------------------------------------------|
| Opcode              | 0x20 POPW                                                                                                 |
| Operation           | dst = *(SP)                                                                                               |
| Address<br>Modes    | dst all modes except literal or immediate (see Note)                                                      |
| Condition<br>Flags  | N = MSB  of  dst $Z = 1,  if  dst == 0$                                                                   |
|                     | C = 0 $V = 0$                                                                                             |
| Exceptions          | Illegal operand exception occurs if literal, expanded-operand type, or immediate mode is used for $dst$ . |
| Example             | POPW (%r2)                                                                                                |
| Note                | If dst is the stack pointer (%sp), the results are indeterminate.                                         |

### PUSHAW

## PUSHAW

•

## PUSH ADDRESS (WORD)

| Assembler<br>Syntax | PUSHAW src Push address (word)                                                                                                                                                       |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Opcode              | 0xE0 PUSHAW                                                                                                                                                                          |
| Operation           | *(SP++) = &src                                                                                                                                                                       |
| Address<br>Modes    | src all modes except literal, register, or immediate                                                                                                                                 |
| Condition<br>Flags  | N = MSB of address of src                                                                                                                                                            |
|                     | Z = 1, if src == 0                                                                                                                                                                   |
|                     | $\mathbf{C} = 0$                                                                                                                                                                     |
|                     | V = 0                                                                                                                                                                                |
| Exceptions          | Illegal operand exception occurs if literal, register, expanded-operand type, or immediate mode is used for <i>src</i> .                                                             |
| Example             | PUSHAW 0x14(%r6)                                                                                                                                                                     |
| Note                | Source operand type is effective address. This instruction is the same as<br>a move address (MOVAW) instruction, except that the destination for<br>PUSHAW is an implied stack push. |

#### **PUSHW**

#### PUSHW

## PUSH (WORD)

| Assembler<br>Syntax | PUSHW src Push (word)                                                              |
|---------------------|------------------------------------------------------------------------------------|
| Opcode              | 0xA0 PUSHW                                                                         |
| Operation           | *(SP++) = src                                                                      |
| Address<br>Modes    | src all modes                                                                      |
| Condition           | N = MSB  of  src                                                                   |
| r lags              | Z = 1, if src == 0                                                                 |
|                     | C = 0                                                                              |
|                     | $\mathbf{V} = 0$                                                                   |
| Exceptions          | Illegal operand exception occurs if expanded-operand type addressing mode is used. |
| Example             | PUSHW (%r2)                                                                        |
|                     |                                                                                    |

RCC

## RCC

## **RETURN ON CARRY CLEAR**

| RCC Return on carry clear |
|---------------------------|
| 0x50 RCC                  |
| if $(C==0)$<br>PC = *(SP) |
| None                      |
| Unchanged                 |
| None                      |
| RCC                       |
|                           |

## RCS

### **RETURN ON CARRY SET**

| Assembler<br>Syntax | RCS Return on carry set   |
|---------------------|---------------------------|
| Opcodes             | 0x58 RCS                  |
| Operation           | if (C==1)<br>PC = $*(SP)$ |
| Address<br>Modes    | None                      |
| Condition<br>Flags  | Unchanged                 |
| Exceptions          | None                      |
| Examples            | RCS                       |

### REQL REQLU

### REQL REQLU

## **RETURN ON EQUAL**

| Assembler<br>Syntax | REQL<br>REQLU      | Return on equal<br>Return on equal | (signed)<br>(unsigned) |
|---------------------|--------------------|------------------------------------|------------------------|
| Opcodes             | 0x7C RH<br>0x6C RH | EQL<br>EQLU                        |                        |
| Operation           | if (Z==1<br>PC =   | )<br>= *(SP)                       |                        |
| Address<br>Modes    | None               |                                    |                        |
| Condition<br>Flags  | Unchange           | d                                  |                        |
| Exceptions          | None               |                                    |                        |
| Examples            | REQL               |                                    |                        |

## RESTORE

#### RESTORE

### **RESTORE REGISTERS**

| Assembler<br>Syntax | RESTORE %rn Restore registers                                                                                                                                                                                                                                                        |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Opcodes             | 0x18 RESTORE                                                                                                                                                                                                                                                                         |
| <b>Operation</b>    | tempa = FP - 28;<br>tempb = *(FP - 28);<br>tempc = FP - 24;<br>while $(n != FP)$ {<br>{<br>register[n] = (tempc)+;<br>n+=1;<br>}<br>FP = tempb;<br>SP = tempa                                                                                                                        |
| Address<br>Modes    | Register mode, where $n$ ranges from 0 through 9                                                                                                                                                                                                                                     |
| Condition<br>Flags  | Unchanged                                                                                                                                                                                                                                                                            |
| Exceptions          | See Notes.                                                                                                                                                                                                                                                                           |
| Examples            | RESTORE %r3                                                                                                                                                                                                                                                                          |
| Notes               | If the operand is not register mode or $n$ is not in the range 0 through 9, the results are indeterminate. Although the results are determinate if $n$ is 0, 1 or 2, the effect is not that of a register restore in a function-calling sequence.                                    |
|                     | RESTORE is the inverse of SAVE and should precede a return from procedure (RET). (Also see SAVE and CALL.) The operand $\% rn$ should be the same as in the corresponding SAVE, where <i>n</i> specifies the number of registers $(9 - n)$ to be restored for the original function. |
|                     | RESTORE implements a stack frame for use in the C language<br>function-calling sequence. The instruction can restore up to six registers<br>(from register 8 through register 3) for use by the function. While<br>restoring these registers, it also adjusts SP and FP.             |
|                     | Illegal operand exception occurs if expanded-operand type address mode is used.                                                                                                                                                                                                      |

RET

## **RETURN FROM PROCEDURE**

| Assembler<br>Syntax | RET Return from procedure                                                                                                                                                                                                                                                                               |  |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Opcodes             | 0x18 RET                                                                                                                                                                                                                                                                                                |  |
| Operation           | tempa = AP;<br>tempb = $*(SP-4)$ ;<br>tempc = $*(SP-8)$ ;<br>AP = tempb;<br>PC = tempc;<br>SP = tempa;                                                                                                                                                                                                  |  |
| Address<br>Modes    | None                                                                                                                                                                                                                                                                                                    |  |
| Condition<br>Flags  | Unchanged                                                                                                                                                                                                                                                                                               |  |
| Exceptions          | None                                                                                                                                                                                                                                                                                                    |  |
| Examples            | RET                                                                                                                                                                                                                                                                                                     |  |
| Note                | The return (RET) is the inverse of the call (CALL) instruction. A restore should precede a return (RET) inside the function being exited. RESTORE sets up the protocol for a C language return from function. RET restores AP, PC, and SP to the values saved on the stack with the corresponding CALL. |  |

# RGEQ

# RETURN ON GREATER THAN OR EQUAL (SIGNED)

| Assembler<br>Syntax | RGEQ Return on greater than or equal (signed) |
|---------------------|-----------------------------------------------|
| Opcodes             | 0x40 RGEQ                                     |
| Operation           | if $((N==0) (Z==1))$<br>PC = *(SP)            |
| Address<br>Modes    | None                                          |
| Condition<br>Flags  | Unchanged                                     |
| Exceptions          | None                                          |
| Examples            | RGEQ                                          |

# RGEQU

# RGEQU

# RETURN ON GREATER THAN OR EQUAL (UNSIGNED)

| Assembler<br>Syntax | RGEQU Return on greater than or equal (unsigned) |
|---------------------|--------------------------------------------------|
| Opcodes             | 0x50 REGEQU                                      |
| Operation           | if (C==0)<br>PC = $*(SP)$                        |
| Address<br>Modes    | None                                             |
| Condition<br>Flags  | Unchanged                                        |
| Exceptions          | None                                             |
| Examples            | RGEQU                                            |

## RGTR

.

### **RETURN ON GREATER THAN (SIGNED)**

| Assembler<br>Syntax | RGTR Return on greater than (signed) |
|---------------------|--------------------------------------|
| Opcodes             | 0x44 RGTR                            |
| Operation           | if $((N \& Z) == 0)$<br>PC = *(SP)   |
| Address<br>Modes    | None                                 |
| Condition<br>Flags  | Unchanged                            |
| Exceptions          | None                                 |
| Examples            | RGTR                                 |

RGTR

### RGTRU

## RGTRU

## **RETURN ON GREATER THAN (UNSIGNED)**

| Assembler<br>Syntax | RGTRU Return on greater than       |
|---------------------|------------------------------------|
| Opcodes             | 0x54 RGTRU                         |
| Operation           | if $((C \& Z) == 0)$<br>PC = *(SP) |
| Address<br>Modes    | None                               |
| Condition<br>Flags  | Unchanged                          |
| Exceptions          | None                               |
| Examples            | RGTRU                              |

# RLEQ

# RLEQ

# **RETURN ON LESS THAN OR EQUAL (SIGNED)**

| Assembler<br>Syntax | RLEQ Return on less than or equal |
|---------------------|-----------------------------------|
| Opcodes             | 0x4C RLEQ                         |
| Operation           | if $((N Z) = = 1)$<br>PC = *(SP)  |
| Address<br>Modes    | None                              |
| Condition<br>Flags  | Unchanged                         |
| Exceptions          | None                              |
| Examples            | RLEQ                              |
|                     |                                   |

# RLEQU

# RLEQU

.

# RETURN ON LESS THAN OR EQUAL (UNSIGNED)

| Assembler<br>Syntax | RLEQU Return on less than or equal (unsigned) |
|---------------------|-----------------------------------------------|
| Opcodes             | 0x5C RLEQU                                    |
| Operation           | if $((C Z) == 1)$<br>PC = *(SP)               |
| Address<br>Modes    | None                                          |
| Condition<br>Flags  | Unchanged                                     |
| Exceptions          | None                                          |
| Examples            | RLEQU                                         |

## RLSS

## **RETURN ON LESS THAN (SIGNED)**

| Assembler<br>Syntax | RLSS Return on less than (signed)   |
|---------------------|-------------------------------------|
| Opcodes             | 0x48 RLSS                           |
| Operation           | if $((N==1)\&(Z==0))$<br>PC = *(SP) |
| Address<br>Modes    | None                                |
| Condition<br>Flags  | Unchanged                           |
| Exceptions          | None                                |
| Examples            | RLSS                                |

## RLSSU

,

### RLSSU

.

## **RETURN ON LESS THAN (UNSIGNED)**

| Assembler<br>Syntax | RLSSU Return on less than (unsigned) |
|---------------------|--------------------------------------|
| Opcodes             | 0x58 RLSSU                           |
| Operation           | if $(C==1)$<br>PC = *(SP)            |
| Address<br>Modes    | None                                 |
| Condition<br>Flags  | Unchanged                            |
| Exceptions          | None                                 |
| Examples            | RLSSU                                |

## **RETURN ON NOT EQUAL**

| Assembler          | RNEQ               | Return on not equal (signed) |    |
|--------------------|--------------------|------------------------------|----|
| Syntax             | RNEQU              | Return on not equal (unsigne | d) |
| Opcodes            | 0x74 RN<br>0x64 RN | IEQ<br>IEQU                  |    |
| Operation          | if (Z==0)<br>PC =  | )<br>= *(SP)                 |    |
| Address<br>Modes   | None               |                              |    |
| Condition<br>Flags | Unchange           | d                            |    |
| Exceptions         | None               |                              |    |
| Examples           | RNEQ               |                              |    |

### ROTW

### ROTW

#### ROTATE

| Assembler<br>Syntax | ROTW count, src, dst Rotate word                                                                                             |
|---------------------|------------------------------------------------------------------------------------------------------------------------------|
| Opcodes             | 0xD8 ROTW                                                                                                                    |
| Operation           | dst = src rotated right (count & 0x1F) bits                                                                                  |
| Address             | count all modes                                                                                                              |
| Ivtodes             | src all modes                                                                                                                |
|                     | dst all modes except literal or immediate                                                                                    |
| Condition           | N = MSB  of  dst                                                                                                             |
| Flags               | Z = 1,  if  dst == 0                                                                                                         |
|                     | C = 0                                                                                                                        |
|                     | V = 0                                                                                                                        |
| Exceptions          | Illegal operand exception occurs if literal or immediate mode is used for $dst$ .                                            |
| Examples            | Before: r0 0F 00 00 7E                                                                                                       |
|                     | = increasing bits                                                                                                            |
|                     | ROTW &0x404,%r0,%r0                                                                                                          |
|                     | After: r0 E0 F0 00 07                                                                                                        |
| Note                | All operands are type word. However, only the five low-order bits of <i>count</i> are used; the high-order bits are ignored. |

-

RSB

### **RETURN FROM SUBROUTINE**

| Assembler<br>Syntax | RSB Return from subroutine (unconditional) |
|---------------------|--------------------------------------------|
| Opcodes             | 0x78 RSB                                   |
| Operation           | PC = *(SP)                                 |
| Address<br>Modes    | None                                       |
| Condition<br>Flags  | Unchanged                                  |
| Exceptions          | None                                       |
| Examples            | RSB                                        |

## RVC

## **RETURN ON OVERFLOW CLEAR**

| Assembler<br>Syntax | RVC Return on overflow clear |
|---------------------|------------------------------|
| Opcodes             | 0x60 RVC                     |
| Operation           | if $(V==0)$<br>PC = *(SP)    |
| Address<br>Modes    | None                         |
| Condition<br>Flags  | Unchanged                    |
| Exceptions          | None                         |
| Examples            | RVC                          |
|                     |                              |

## RVS

### **RETURN ON OVERFLOW SET**

| Assembler<br>Syntax | RVS Return on overflow set |
|---------------------|----------------------------|
| Opcodes             | 0x68 RVS                   |
| Operation           | if $(V==1)$<br>PC = *(SP)  |
| Address<br>Modes    | None                       |
| Condition<br>Flags  | Unchanged                  |
| Exceptions          | None                       |
| Examples            | RVS                        |

RVS

## SAVE

## SAVE

## SAVE REGISTERS

| Assembler<br>Syntax | SAVE %rn Save registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Opcodes             | 0x10 SAVE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Operation           | temp = SP<br>*(SP++) = FP<br>while $(n = FP)$ {<br>*(SP++) = register[n]<br>n+=1;<br>}<br>SP =temp + 28;<br>FP = SP;                                                                                                                                                                                                                                                                                                                                                                                                                |
| Address<br>Modes    | Register mode, where $n$ ranges from 0 through 9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Condition<br>Flags  | Unchanged                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Exceptions          | See Notes.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Examples            | SAVE %r3 (see Figure 3-9)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Notes               | If the operand is not register mode or $n$ is not in the range 0 to 9, the results are indeterminate. However, if $n$ is 0, 1, or 2, the results are determinate, but SP and FP will not point beyond the register-save area.                                                                                                                                                                                                                                                                                                       |
|                     | Temp is a temporary register, and <i>n</i> specifies the number of registers $(9 - n)$ to be saved for the calling function.                                                                                                                                                                                                                                                                                                                                                                                                        |
|                     | SAVE implements a stack frame for use in the C language function-<br>calling sequence. It should be the first statement in the called function.<br>(Also see <b>Restore</b> and <b>Return from Procedure</b> instructions.) SAVE can<br>save up to six registers, from register 8 (r8) through register 3 (r3),<br>freeing them for the new function. After saving these registers, SAVE<br>adjusts SP and FP to point beyond the end of a fixed-size register-save<br>area. Figure 3-9 shows the stack after executing 'SAVE %r3'. |
|                     | Illegal operand exception occurs if expanded-operand type addressing mode is used.                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

.

# COPROCESSOR OPERATION (no operands)

| Assembler<br>Syntax | SPOP word Coprocessor operation                                                                                                                                                                                                                                                              |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Opcodes             | 0x32 SPOP                                                                                                                                                                                                                                                                                    |
| Operation           | <pre>/* coprocessor operation executes the following     processor operations */ { "word" is written out with an access status of     "coprocessor broadcast" } { wait for "coprocessor done" } { a word is written into PSW with an access status of     "coprocessor status fetch" }</pre> |
| Address<br>Modes    | None valid, word = $32$ -bit value                                                                                                                                                                                                                                                           |
| Condition<br>Flags  | Determined by the coprocessor status.                                                                                                                                                                                                                                                        |
| Exceptions          | External memory fault may occur.                                                                                                                                                                                                                                                             |
| Examples            | SPOP 0XFFFFFFF                                                                                                                                                                                                                                                                               |
| Note:               | Can be used only with computers containing an MAU.                                                                                                                                                                                                                                           |

#### SPOPRS SPOPRD SPOPRT

### **COPROCESSOR OPERATION READ**

| Assembler          | SPOPRS word, src Coprocessor operation read single                              |
|--------------------|---------------------------------------------------------------------------------|
| Syntax             | SPOPRD word, src Coprocessor operation read double                              |
| 5                  | SPOPPT word, src Coprocessor operation read triple                              |
|                    |                                                                                 |
| Opcodes            | 0x22 SPOPRS                                                                     |
|                    | 0x02 SPOPRD                                                                     |
|                    | 0x06 SPOPRT                                                                     |
| Operation          | /* coprocessor operation read executes the following<br>processor operations */ |
|                    | { "word" is written out with an access status of                                |
|                    | "coprocessor broadcast" }                                                       |
|                    | { "src" is read with an access status of                                        |
|                    | "coprocessor data fetch" }                                                      |
|                    | { wait for "coprocessor done" }                                                 |
|                    | { a word is written into PSW with an access status of                           |
|                    | "coprocessor status fetch" }                                                    |
| Address            | word none valid, 32-bit value                                                   |
| Modes              | src all modes except register, literal, or immediate                            |
|                    |                                                                                 |
| Condition<br>Flags | Determined by the coprocessor status                                            |
| Exceptions         | External memory fault may occur.                                                |
| Examples           | SPOPRS 0xF379FFFF,*\$0xFF37                                                     |
|                    | SPOPRD 0xFFFFFFF,%r3                                                            |
|                    | SPOPRT 0x00000000,(%r4)                                                         |
| Note:              | Can be used only with computers containing an MAU.                              |



#### SPOPS2 SPOPD2 SPOPT2

## **COPROCESSOR OPERATION, 2-ADDRESS**

| Assembler<br>Syntax | SPOPS2 word, src, dst Coprocessor operation single,<br>2-address                                                                                                                                                                                                                                                                                                                                                                                |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     | SPOPD2 word,src,dst Coprocessor operation double,<br>2-address                                                                                                                                                                                                                                                                                                                                                                                  |
|                     | SPOPT2 word, src, dst Coprocessor operation triple,<br>2-address                                                                                                                                                                                                                                                                                                                                                                                |
| Opcodes             | 0x23 SPOPWS<br>0x03 SPOPWD<br>0x07 SPOPWT                                                                                                                                                                                                                                                                                                                                                                                                       |
| Operation           | <pre>/* coprocessor operation executes the following     processor operations */ { "word" is written out with an access status of     "coprocessor broadcast" } { "src" is read with an access status of "coprocessor     data fetch" } { wait for "coprocessor done" } { a word is written into PSW with an access status of     "coprocessor status fetch" } { "dst" is written with an access status of     "coprocessor data write" }</pre> |
| Address             | word none valid, 32-bit value                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Modes               | <i>src</i> all modes except register, literal, or immediate<br><i>dst</i> all modes except register, literal, or immediate                                                                                                                                                                                                                                                                                                                      |
| Condition<br>Flags  | Determined by the coprocessor status                                                                                                                                                                                                                                                                                                                                                                                                            |
| Exceptions          | External memory fault may occur.                                                                                                                                                                                                                                                                                                                                                                                                                |
| Examples            | SPOPS2 0xFF,4(%r0)                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                     | SPOPD2 UXFFF,%r3<br>SPOPT2 0xFE,(%r0)                                                                                                                                                                                                                                                                                                                                                                                                           |
| Note:               | Can be used only with computers containing an MAU.                                                                                                                                                                                                                                                                                                                                                                                              |



#### **COPROCESSOR OPERATION WRITE**

| Assembler          | SPOPWS word, dst Coprocessor operation write single                                   |
|--------------------|---------------------------------------------------------------------------------------|
| Syntax             | SPOPWD word, dst Coprocessor operation write double                                   |
|                    | SPOPWT word,dst Coprocessor operation write triple                                    |
| Opcodes            | 0x33 SPOPWS                                                                           |
|                    | 0x13 SPOPWD                                                                           |
|                    | 0x17 SPOPWT                                                                           |
| Operation          | /* coprocessor operation write executes the following processor operations */         |
|                    | <pre>{ "word" is written out with an access status of</pre>                           |
|                    | { wait for "coprocessor done" }                                                       |
|                    | { a word is written into PSW with an access status of<br>(conrocessor status fetch" } |
|                    | { "dst" is written with an access status of                                           |
|                    | " coprocessor data write" }                                                           |
| Address            | word none valid, 32-bit value                                                         |
| Modes              | dst all modes except register, literal, or immediate                                  |
| Condition<br>Flags | Determined by the coprocessor status.                                                 |
| Exceptions         | External memory fault may occur.                                                      |
| Examples           | SPOPWS 0x00,%r0                                                                       |
| ~                  | SPOPWD 0x0F,(%r1)                                                                     |
|                    | SPOPWT 0x1000,4(%r2)                                                                  |
| Note:              | Can be used only with computers containing an MAU.                                    |

### STRCPY

#### STRCPY

#### STRING COPY

| Assembler<br>Syntax | STRCPY String copy                                                                                        |
|---------------------|-----------------------------------------------------------------------------------------------------------|
| Opcodes             | 0x3035 STRCPY                                                                                             |
| Operation           | <pre>while ((*r1 = *r0)!=0){     {disable interrupts}     r0++;     r1++;     {enable interrupts} }</pre> |
| Address<br>Modes    | None                                                                                                      |
| Condition<br>Flags  | Unchanged                                                                                                 |
| Exceptions          | External memory fault may occur in the middle of an iteration.                                            |
| Examples            | Before: r0 00 00 01 00                                                                                    |
|                     | r1 00 00 40 00                                                                                            |
|                     | = increasing bits                                                                                         |

The byte locations starting at 0x100 contain the values 0x01, 0x24, 0xE6, 0x7F, 0x11, and 0x00 (location 0x105).

#### STRCPY



The byte locations from 0x4000 through 0x4005 now contain the same values as locations 0x100 through 0x105.

#### **STRCPY**

Notes

Opcode occupies 16 bits. All operands are defined implicitly in the registers, r0 and r1, that function as byte pointers. These registers must be preset with the following information before executing STRCPY:

- r0 Address of source string
- r1 Address of destination string

STRCPY implements the string-copy function commonly used in C language. The instruction may be interrupted *only* at the end of an iteration. A memory fault may occur in the middle of an iteration. To restart the instruction after a fault, execute STRCPY again; the registers are updated after the only memory access that could cause the fault. The assignment is a byte move and both R0 and R1 are incremented by 1 at each iteration. Execution of STRCPY is finished when a null (zero) byte is reached. The null byte is always copied.

#### STREND

#### STREND

STRING END

| Assembler<br>Syntax | STREND String end                                              |
|---------------------|----------------------------------------------------------------|
| Opcode              | 0x301F STREND                                                  |
| Operation           | while (*r0 !=0){<br>r0++;<br>}                                 |
| Address<br>Modes    | None                                                           |
| Condition<br>Flags  | Unchanged                                                      |
| Exceptions          | External memory fault may occur in the middle of an iteration. |
| Examples            | Before: r0 00 00 04 00                                         |
|                     | = increasing bits                                              |

The byte locations 0x400 through 0x404 contain the values 0x44, 0x55, 0x01, 0x22, 0x00, respectively.

STREND

00 00 04 04 After: r0

Notes

Opcode occupies 16 bits. The operand is defined implicitly in the register r0, a byte pointer that must be preset with the starting address of the source C language string. STREND moves the pointer to the end of the string and could be used as part of a string-length or string-concatenation function. The instruction may be interrupted at any time. A memory fault may occur in the middle of an iteration. To restart the instruction after a fault, execute STREND again; the register is updated after the only instruction that could cause the fault. Each iteration tests a byte and increments the pointer r0 by 1. Execution of STREND terminates when a null (zero) byte is found; r0 will be left with the address of the null byte.

#### SUBB2 SUBH2 SUBW2

#### SUBB2 SUBH2 SUBW2

#### SUBTRACT

| Assembler<br>Syntax | SUBB2 src,dstSubtract byteSUBH2 src,dstSubtract halfwordSUBW2 src,dstSubtract word     |
|---------------------|----------------------------------------------------------------------------------------|
| Opcodes             | 0xBF SUBB2<br>0xBE SUBH2<br>0xBC SUBW2                                                 |
| Operation           | dst = dst - src                                                                        |
| Address             | src all modes                                                                          |
| Ivioues             | dst all modes except literal or immediate                                              |
| Condition           | N = 1, if $(dst - src) < 0$                                                            |
| riags               | Z = 1, if $(dst - src) == 0$                                                           |
|                     | C = 1, if borrow from sign bit of dst                                                  |
|                     | V = 1, if overflow                                                                     |
| Exceptions          | Illegal operand exception occurs if literal or immediate mode is used for <i>dst</i> . |
|                     | Integer overflow exception occurs if there is truncation.                              |
| Examples            | SUBB2 %r6,*\$0x30(%r2)<br>SUBH2 %r0,\$resulth<br>SUBW2 %r3,\$resultw                   |
|                     |                                                                                        |

#### SUBB3 SUBH3 SUBW3

## SUBTRACT, 3 ADDRESS

| Assembler<br>Syntax | SUBB3src1,src2,dstSubtract byte, 3 addressSUBH3src1,src2,dstSubtract halfword, 3 addressSUBW3src1,src2,dstSubtract word, 3 address |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------|
| Opcodes             | 0xFFSUBB30xFESUBH30xFCSUBW3                                                                                                        |
| Operation           | dst = src2 - src1                                                                                                                  |
| Address             | src1 all modes                                                                                                                     |
| Ivlodes             | src2 all modes                                                                                                                     |
|                     | dst all modes except literal or immediate                                                                                          |
| Condition<br>Flags  | N = 1, if $(src2 - src1) < 0$                                                                                                      |
|                     | Z = 1, if $(src2 - src1) == 0$                                                                                                     |
|                     | C = 1, if carry out of sign bit of dst                                                                                             |
|                     | V = 1, if overflow                                                                                                                 |
| Exceptions          | Illegal operand exception occurs if literal or immediate mode is used for $dst$ .                                                  |
|                     | Integer overflow exception occurs if there is truncation.                                                                          |
| Examples            | SUBB3 %r3,*\$0x1005,%r2<br>SUBH3 %r1,%r3,%r0<br>SUBW3 \$N1,\$N2,\$result                                                           |
|                     |                                                                                                                                    |

. x

## SWAP (INTERLOCKED)

| Assembler          | SWAPBI dst Swap byte (interlocked)                                                                                                                                                                                                                  |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax             | SWAPHI dst Swap halfword (interlocked)                                                                                                                                                                                                              |
|                    | SWAPWI dst Swap word (interlocked)                                                                                                                                                                                                                  |
| Opcodes            | 0x1F SWAPBI<br>0x1E SWAPHI<br>0x1C SWAPWI                                                                                                                                                                                                           |
| Operation          | {set interlock}<br>tempa = $dst$<br>dst = r0<br>r0 = tempa                                                                                                                                                                                          |
| Address<br>Modes   | dst all modes except register, literal, or immediate                                                                                                                                                                                                |
| Condition<br>Flags | N = MSB  of  r0<br>Z = 1, if r0 == 0                                                                                                                                                                                                                |
|                    | C = 0 $V = 0$                                                                                                                                                                                                                                       |
| Exceptions         | Illegal operand exception occurs if register, literal, expanded-operand type, or immediate mode is used for <i>dst</i> .                                                                                                                            |
| Examples           | The swap instruction can manipulate interlocks for multiprocessors.<br>Suppose location A is the interlock for a critical section of code and a<br>nonzero means the lock is busy. Then, the following instructions<br>provide a busy-waiting loop: |
|                    | MOVW &1,%r0<br>L1: SWAPWI A<br>BNEB L1                                                                                                                                                                                                              |
| Note               | Final value of r0 sets the condition codes. The SAS code is read interlocked (7) for both the read and write bus transactions.                                                                                                                      |

#### TSTB TSTH TSTW

#### TSTB TSTH TSTW

## TEST

| Assembler          | TSTB src Test byte                                                                                                                     |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| Syntax             | TSTH src Test halfword                                                                                                                 |
|                    | TSTW src Test word                                                                                                                     |
| Opcodes            | 0x2B TSTB                                                                                                                              |
|                    | 0x2A TSTH                                                                                                                              |
|                    | 0x28 TSTW                                                                                                                              |
| Operation          | temp = src-0                                                                                                                           |
| Address            | src all modes                                                                                                                          |
| Modes              |                                                                                                                                        |
| Condition<br>Flogs | N = 1, if src < 0 (signed)                                                                                                             |
| Гадз               | Z = 1, if src == 0                                                                                                                     |
|                    | C = 0                                                                                                                                  |
|                    | V = 0                                                                                                                                  |
| Exceptions         | None                                                                                                                                   |
| Examples           | TSTH 14(%r2)                                                                                                                           |
| Note               | This instruction only sets condition codes. Its action is the same as a compare instruction, where the first operand is zero, such as: |
|                    |                                                                                                                                        |

#### CMPB &0,src2

However, test is faster because it is one byte shorter.


## **EXCLUSIVE OR**

| Assembler<br>Syntax | XORB2src,dstExclusive OR byteXORH2src,dstExclusive OR halfwordXORW2src,dstExclusive OR word |
|---------------------|---------------------------------------------------------------------------------------------|
| Opcodes             | 0xB7 XORB2<br>0xB6 XORH2<br>0xB4 XORW2                                                      |
| Operation           | $dst = dst \circ src$                                                                       |
| Address             | src all modes                                                                               |
| Modes               | dst all modes except literal or immediate                                                   |
| Condition           | N = MSB of $dst$                                                                            |
| Flags               | Z = 1, if $dst == 0$                                                                        |
|                     | $\mathbf{C} = 0$                                                                            |
|                     | V = 1, if result must be truncated to fit dst size                                          |
| Exceptions          | Illegal operand exception occurs if literal or immediate mode is used for $dst$ .           |
| Examples            | XORB2 &40,4(%r4)<br>XORH2 %r1,\$result<br>XORW2 4(%r1),\$result                             |

# **EXCLUSIVE OR, 3 ADDRESS**

| Assembler<br>Syntax | XORB3src1,src2,dstExclusive OR byte, 3 addressXORH3src1,src2,dstExclusive OR halfword, 3 addressXORW3src1,src2,dstExclusive OR word, 3 address |  |  |  |  |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Opcodes             | 0xF7 XORB3<br>0xF6 XORH3<br>0xF4 XORW3                                                                                                         |  |  |  |  |
| Operation           | $dst = src2 \ src1$                                                                                                                            |  |  |  |  |
| Address             | src1 all modes                                                                                                                                 |  |  |  |  |
| Modes               | src2 all modes                                                                                                                                 |  |  |  |  |
|                     | dst all modes except literal or immediate                                                                                                      |  |  |  |  |
| Condition           | N = MSB of $dst$                                                                                                                               |  |  |  |  |
| Flags               | Z = 1, if $dst == 0$                                                                                                                           |  |  |  |  |
|                     | C = 0                                                                                                                                          |  |  |  |  |
|                     | V = 1, if result must be truncated to fit <i>dst</i> size                                                                                      |  |  |  |  |
| Exceptions          | Illegal operand exception occurs if literal or immediate mode is used for <i>dst</i> .                                                         |  |  |  |  |
| Examples            | XORB3 &4,*12(%r3),*\$0x400<br>XORH3 %r1,4(%r1),%r0<br>XORW3 %r0,%r1,%r3                                                                        |  |  |  |  |
|                     |                                                                                                                                                |  |  |  |  |

| Table A-3. Data Transfer Instruction Group |          |        |  |
|--------------------------------------------|----------|--------|--|
| Instruction                                | Mnemonic | Opcode |  |
| Move:                                      |          | ,      |  |
| Move byte                                  | MOVB     | 0x87   |  |
| Move halfword                              | MOVH     | 0x86   |  |
| Move word                                  | MOVW     | 0x84   |  |
| Move address (word)                        | MOVAW    | 0x04   |  |
| Move complemented byte                     | МСОМВ    | 0x8B   |  |
| Move complemented halfword                 | мсомн    | 0x8A   |  |
| Move complemented word                     | MCOMW    | 0x88   |  |
| Move negated byte                          | MNEGB    | 0x8F   |  |
| Move negated halfword                      | MNEGH    | 0x8E   |  |
| Move negated word                          | MNEGW    | 0x8C   |  |
| Move version number                        | MVERNO   | 0x3009 |  |
| Swap (Interlocked):                        |          |        |  |
| Swap byte interlocked                      | SWAPBI   | 0x1F   |  |
| Swap halfword interlocked                  | SWAPHI   | 0x1E   |  |
| Swap word interlocked                      | SWAPWI   | 0x1C   |  |
| Block Operations:                          |          |        |  |
| Move block of words                        | MOVBLW   | 0x3019 |  |
| Field Operations:                          |          |        |  |
| Extract field byte                         | EXTFB    | 0xCF   |  |
| Extract field halfword                     | EXTFH    | 0xCE   |  |
| Extract field word                         | EXTFW    | 0xCC   |  |
| Insert field byte                          | INSFB    | 0xCB   |  |
| Insert field halfword                      | INSFH    | 0xCA   |  |
| Insert field word                          | INSFW    | 0xC8   |  |
| String Operations:                         |          |        |  |
| String copy                                | STRCPY   | 0x3035 |  |
| String end                                 | STREND   | 0x301F |  |

## A.3 INSTRUCTION SET SUMMARY BY FUNCTION

| Table A-4. Arithmetic Instruction Group |          |        |  |
|-----------------------------------------|----------|--------|--|
| Instruction                             | Mnemonic | Opcode |  |
| Add:                                    |          |        |  |
| Add byte                                | ADDB2    | 0x9F   |  |
| Add halfword                            | ADDH2    | 0x9E   |  |
| Add word                                | ADDW2    | 0x9C   |  |
| Add byte, 3-address                     | ADDB3    | 0xDF   |  |
| Add halfword, 3-address                 | ADDH3    | 0xDE   |  |
| Add word, 3-address                     | ADDW3    | 0xDC   |  |

## WE 32100 MICROPROCESSOR INSTRUCTION SET Instruction Set Summary by Function

| Table A-4. Arithmetic Instruction Group (Continued) |       |             |  |  |
|-----------------------------------------------------|-------|-------------|--|--|
| Instruction Mnemonic Opcod                          |       |             |  |  |
| Subtract:                                           |       |             |  |  |
| Subtract byte                                       | SUBB2 | <b>0xBF</b> |  |  |
| Subtract halfword                                   | SUBH2 | 0xBE        |  |  |
| Subtract word                                       | SUBW2 | 0xBC        |  |  |
| Subtract byte, 3-address                            | SUBB3 | 0xFF        |  |  |
| Subtract halfword, 3-address                        | SUBH3 | <b>0xFE</b> |  |  |
| Subtract word, 3-address                            | SUBW3 | 0xFC        |  |  |
| Increment:                                          |       |             |  |  |
| Increment byte                                      | INCB  | 0x93        |  |  |
| Increment halfword                                  | INCH  | 0x92        |  |  |
| Increment word                                      | INCW  | 0x90        |  |  |
| Decrement:                                          |       |             |  |  |
| Decrement byte                                      | DECB  | 0x97        |  |  |
| Decrement halfword                                  | DECH  | 0x96        |  |  |
| Decrement word                                      | DECW  | 0x94        |  |  |
| Multiply:                                           |       | <u> </u>    |  |  |
| Multiply byte                                       | MULB2 | 0xAB        |  |  |
| Multiply halfword                                   | MULH2 | 0xAA        |  |  |
| Multiply word                                       | MULW2 | 0xA8        |  |  |
| Multiply byte, 3-address                            | MULB3 | <b>OxEB</b> |  |  |
| Multiply halfword, 3-address                        | MULH3 | 0xEA        |  |  |
| Multiply word, 3-address                            | MULW3 | 0xE8        |  |  |
| Divide:                                             |       |             |  |  |
| Divide byte                                         | DIVB2 | 0xAF        |  |  |
| Divide halfword                                     | DIVH2 | 0xAE        |  |  |
| Divide word                                         | DIVW2 | 0xAC        |  |  |
| Divide byte, 3-address                              | DIVB3 | <b>0xEF</b> |  |  |
| Divide halfword, 3-address                          | DIVH3 | 0xEE        |  |  |
| Divide word, 3-address                              | DIVW3 | 0xEC        |  |  |
| Modulo:                                             |       |             |  |  |
| Modulo byte                                         | MODB2 | 0xA7        |  |  |
| Modulo halfword                                     | MODH2 | 0xA6        |  |  |
| Modulo word                                         | MODW2 | 0xA4        |  |  |
| Modulo byte, 3-address                              | MODB3 | 0xE7        |  |  |
| Modulo halfword, 3-address                          | MODH3 | 0xE6        |  |  |
| Modulo word, 3-address                              | MODW3 | 0xE4        |  |  |
| Arithmetic Shift:                                   |       |             |  |  |
| Arithmetic left shift word                          | ALSW3 | 0xC0        |  |  |
| Arithmetic right shift byte                         | ARSB3 | 0xC7        |  |  |
| Arithmetic right shift halfword                     | ARSH3 | 0xC6        |  |  |
| Arithmetic right shift word                         | ARSW3 | 0xC4        |  |  |

| Table A-5. Logical Instruction Group |        |      |  |  |
|--------------------------------------|--------|------|--|--|
| Instruction                          | Opcode |      |  |  |
| AND:                                 |        |      |  |  |
| AND byte                             | ANDB2  | 0xBB |  |  |
| AND halfword                         | ANDH2  | 0xBA |  |  |
| AND word                             | ANDW2  | 0xB8 |  |  |
| AND byte, 3-address                  | ANDB3  | 0xFB |  |  |
| AND halfword, 3-address              | ANDH3  | 0xFA |  |  |
| AND word, 3-address                  | ANDW3  | OxF8 |  |  |
| Exclusive OR (XOR):                  |        |      |  |  |
| Exclusive OR byte                    | XORB2  | 0xB7 |  |  |
| Exclusive OR halfword                | XORH2  | 0xB6 |  |  |
| Exclusive OR word                    | XORW2  | 0xB4 |  |  |
| Exclusive OR byte, 3-address         | XORB3  | 0xF7 |  |  |
| Exclusive OR halfword, 3-address     | XORH3  | 0xF6 |  |  |
| Exclusive OR word, 3-address         | XORW3  | 0xF4 |  |  |
| OR:                                  |        |      |  |  |
| OR byte                              | ORB2   | 0xB3 |  |  |
| OR halfword                          | ORH2   | 0xB2 |  |  |
| OR word                              | ORW2   | 0xB0 |  |  |
| OR byte, 3-address                   | ORB3   | 0xF3 |  |  |
| OR halfword, 3-address               | ORH2   | 0xF2 |  |  |
| OR word, 3-address                   | ORW3   | 0xF0 |  |  |
| Compare or Test:                     |        | 1    |  |  |
| Compare byte                         | СМРВ   | 0x3F |  |  |
| Compare halfword                     | СМРН   | 0x3E |  |  |
| Compare word                         | CMPW   | 0x3C |  |  |
| Test byte                            | TSTB   | 0x2B |  |  |
| Test halfword                        | TSTH   | 0x2A |  |  |
| Test word                            | TSTW   | 0x28 |  |  |
| Bit test byte                        | BITB   | 0x3B |  |  |
| Bit test halfword                    | BITH   | 0x3A |  |  |
| Bit test word                        | BITW   | 0x38 |  |  |
| Clear:                               |        |      |  |  |
| Clear byte                           | CLRB   | 0x83 |  |  |
| Clear halfword                       | CLRH   | 0x82 |  |  |
| Clear word                           | CLRW   | 0x80 |  |  |
| Rotate or Logical Shift:             |        | 1    |  |  |
| Rotate word                          | ROTW   | 0xD8 |  |  |
| Logical left shift byte              | LLSB3  | 0xD3 |  |  |
| Logical left shift halfword          | LLSH3  | 0xD2 |  |  |
| Logical left shift word              | LLSW3  | 0xD0 |  |  |
| Logical right shift word             | LRSW3  | 0xD4 |  |  |

## WE 32100 MICROPROCESSOR INSTRUCTION SET Instruction Set Summary by Function

| Table A-6. Program Control Instruction Group                |          |        |  |
|-------------------------------------------------------------|----------|--------|--|
| Instruction                                                 | Mnemonic | Opcode |  |
| Unconditional Transfer:                                     |          | ·.     |  |
| Branch with byte (8-bit) displacement                       | BRB      | 0x7B   |  |
| Branch with halfword (16-bit) displacement                  | BRH      | 0x7A   |  |
| Jump                                                        | JMP      | 0x24   |  |
| Conditional Transfers:                                      |          |        |  |
| Branch on carry clear byte                                  | BCCB     | 0x53*  |  |
| Branch on carry clear halfword                              | BCCH     | 0x52*  |  |
| Branch on carry set byte                                    | BCSB     | 0x5B   |  |
| Branch on carry set halfword                                | BCSH     | 0x5A*  |  |
| Branch on overflow clear, byte displacement                 | BVCB     | 0x63   |  |
| Branch on overflow clear, halfword displacement             | BVCH     | 0x62   |  |
| Branch on overflow set, byte displacement                   | BVSB     | 0x6B   |  |
| Branch on overflow set, halfword displacement               | BVSH     | 0x6A   |  |
| Branch on equal byte (duplicate)                            | BEB      | 0x6F   |  |
| Branch on equal byte                                        | BEB      | 0x7F   |  |
| Branch on equal halfword (duplicate)                        | BEH      | 0x6E   |  |
| Branch on equal halfword                                    | BEH      | 0x7E   |  |
| Branch on not equal byte (duplicate)                        | BNEB     | 0x67   |  |
| Branch on not equal byte                                    | BNEB     | 0x77   |  |
| Branch on not equal halfword (duplicate)                    | BNEH     | 0x66   |  |
| Branch on not equal halfword                                | BNEH     | 0x76   |  |
| Branch on less than byte (signed)                           | BLB      | 0x4B   |  |
| Branch on less than halfword (signed)                       | BLH      | 0x4A   |  |
| Branch on less than byte (unsigned)                         | BLUB     | 0x5B*  |  |
| Branch on less than halfword (unsigned)                     | BLUH     | 0x5A*  |  |
| Branch on less than or equal byte (signed)                  | BLEB     | 0x4F   |  |
| Branch on less than or equal halfword (signed)              | BLEH     | 0x4E   |  |
| Branch on less than or equal byte (unsigned)                | BLEUB    | 0x5F   |  |
| Branch on less than or equal halfword (unsigned)            | BLEUH    | 0x5E   |  |
| Branch on greater than byte (signed)                        | BGB      | 0x47   |  |
| Branch on greater than halfword (signed)                    | BGH      | 0x46   |  |
| Branch on greater than byte (unsigned)                      | BGUB     | 0x57   |  |
| Branch on greater than halfword (unsigned) BGUH 0x5         |          |        |  |
| Branch on greater than or equal byte (signed)               | BGEB     | 0x43   |  |
| Branch on greater than or equal halfword (signed) BGEH 0x42 |          |        |  |
| Branch on greater than or equal byte (unsigned) BGEUB 0x53* |          |        |  |
| Branch on greater than or equal halfword (unsigned)         | BGEUH    | 0x52*  |  |

\* Indicates that opcode matches another instruction mnemonic with the same operation.

| Table A-6. Program Control Instruction Group (Continued) |                          |       |  |  |
|----------------------------------------------------------|--------------------------|-------|--|--|
| Instruction Mnemonic Opcode                              |                          |       |  |  |
| Conditional Transfers (Continued):                       |                          |       |  |  |
| Return on carry clear                                    | RCC                      | 0x50* |  |  |
| Return on carry set                                      | RCS                      | 0x58* |  |  |
| Return on overflow clear                                 | RVC                      | 0x60  |  |  |
| Return on overflow set                                   | RVS                      | 0x68  |  |  |
| Return on equal (unsigned)                               | REQLU                    | 0x6C  |  |  |
| Return on equal (signed)                                 | REQL                     | 0x7C  |  |  |
| Return on not equal (unsigned)                           | RNEQU                    | 0x64  |  |  |
| Return on not equal (signed)                             | RNEQ                     | 0x74  |  |  |
| Return on less than (signed)                             | RLSS                     | 0x48  |  |  |
| Return on less than (unsigned)                           | RLSSU                    | 0x58* |  |  |
| Return on less than or equal (signed)                    | RLEQ                     | 0x4C  |  |  |
| Return on less than or equal (unsigned)                  | RLEQU                    | 0x5C  |  |  |
| Return on greater than (signed) RGTR 02                  |                          |       |  |  |
| Return on greater than (unsigned) RGTRU 0x               |                          |       |  |  |
| Return on greater than or equal (signed) RGEQ 0x4        |                          |       |  |  |
| Return on greater than or equal (unsigned)               | RGEQU                    | 0x50* |  |  |
| Subroutine Transfer:                                     |                          |       |  |  |
| Branch to subroutine, byte displacement                  | BSBB                     | 0x37  |  |  |
| Branch to subroutine, halfword displacement BSBH 0x      |                          |       |  |  |
| Jump to subroutine                                       | JSB                      | 0x34  |  |  |
| Return from subroutine                                   | RSB                      | 0x78  |  |  |
| Procedure Transfer:                                      |                          |       |  |  |
| Save registers                                           | SAVE                     | 0x10  |  |  |
| Restore registers RESTORE 0x                             |                          |       |  |  |
| Call procedure                                           | Call procedure CALL 0x20 |       |  |  |
| Return from procedure RET 0x                             |                          |       |  |  |

\* Indicates that opcode matches another instruction mnemonic with the same operation.

### WE 32100 MICROPROCESSOR INSTRUCTION SET Instruction Set Summary by Function

| Table A-7. Coprocessor Instructions    |        |      |  |  |  |
|----------------------------------------|--------|------|--|--|--|
| Instruction Mnemonic Opcode            |        |      |  |  |  |
| Coprocessor operation                  | SPOP   | 0x32 |  |  |  |
| Coprocessor operation read single      | SPOPRS | 0x22 |  |  |  |
| Coprocessor operation read double      | SPOPRD | 0x02 |  |  |  |
| Coprocessor operation read triple      | SPOPRT | 0x06 |  |  |  |
| Coprocessor operation single 2-address | SPOPS2 | 0x23 |  |  |  |
| Coprocessor operation double 2-address | SPOPD2 | 0x03 |  |  |  |
| Coprocessor operation triple 2-address | SPOPT2 | 0x07 |  |  |  |
| Coprocessor operation write single     | SPOPWS | 0x33 |  |  |  |
| Coprocessor operation write double     | SPOPWD | 0x13 |  |  |  |
| Coprocessor operation write triple     | SPOPWT | 0x17 |  |  |  |

Note: Can be used only with computers containing a MAU.

| Instruction Mnemonic Opcod |        |      |  |  |
|----------------------------|--------|------|--|--|
| Stack Operations:          |        | 1    |  |  |
| Push address word          | PUSHAW | 0xE0 |  |  |
| Push word                  | PUSHW  | 0xA0 |  |  |
| Pop word                   | POPW   | 0x20 |  |  |
| Miscellaneous:             |        |      |  |  |
| No operation, 1 byte       | NOP    | 0x70 |  |  |
| No operation, 2 bytes      | NOP2   | 0x73 |  |  |
| No operation, 3 bytes      | NOP3   | 0x72 |  |  |
| Breakpoint trap            | BPT    | 0x2E |  |  |
| Extended opcode            | EXTOP  | 0x14 |  |  |
| Cache flush                | CFLUSH | 0x27 |  |  |

| A.4 | INSTRUCTION | SET | <b>SUMMARY</b> | BY | MNEMONIC |
|-----|-------------|-----|----------------|----|----------|
|-----|-------------|-----|----------------|----|----------|

| Table A-9. Instruction Set Summary by Mnemonic |        |                                                     |  |  |
|------------------------------------------------|--------|-----------------------------------------------------|--|--|
| Mnemonic                                       | Opcode | Instruction                                         |  |  |
| ADDB2                                          | 0x9F   | Add byte                                            |  |  |
| ADDB3                                          | 0xDF   | Add byte, 3-address                                 |  |  |
| ADDH2                                          | 0x9E   | Add halfword                                        |  |  |
| ADDH3                                          | 0xDE   | Add halfword, 3-address                             |  |  |
| ADDW2                                          | 0x9C   | Add word                                            |  |  |
| ADDW3                                          | 0xDC   | Add word, 3-address                                 |  |  |
| ALSW3                                          | 0xC0   | Arithmetic left shift word                          |  |  |
| ANDB2                                          | 0xBB   | AND byte                                            |  |  |
| ANDB3                                          | 0xFB   | AND byte, 3-address                                 |  |  |
| ANDH2                                          | 0xBA   | AND halfword                                        |  |  |
| ANDH3                                          | 0xFA   | AND halfword, 3-address                             |  |  |
| ANDW2                                          | 0xB8   | AND word                                            |  |  |
| ANDW3                                          | 0xF8   | AND word, 3-address                                 |  |  |
| ARSB3                                          | 0xC7   | Arithmetic right shift byte                         |  |  |
| ARSH3                                          | 0xC6   | Arithmetic right shift halfword                     |  |  |
| ARSW3                                          | 0xC4   | Arithmetic right shift word                         |  |  |
| BCCB                                           | 0x53*  | Branch on carry clear byte                          |  |  |
| BCCH                                           | 0x52*  | Branch on carry clear halfword                      |  |  |
| BCSB                                           | 0x5B*  | Branch on carry set byte                            |  |  |
| BCSH                                           | 0x5A*  | Branch on carry set halfword                        |  |  |
| BEB                                            | 0x6F   | Branch on equal byte (duplicate)                    |  |  |
| BEB                                            | 0x7F   | Branch on equal byte                                |  |  |
| BEH                                            | 0x6E   | Branch on equal halfword (duplicate)                |  |  |
| BEH                                            | 0x7E   | Branch on equal halfword                            |  |  |
| BGB                                            | 0x47   | Branch on greater than byte (signed)                |  |  |
| BGEB                                           | 0x43   | Branch on greater than or equal byte (signed)       |  |  |
| BGEH                                           | 0x42   | Branch on greater than or equal halfword (signed)   |  |  |
| BGEUB                                          | 0x53*  | Branch on greater than or equal byte (unsigned)     |  |  |
| BGEUH                                          | 0x52*  | Branch on greater than or equal halfword (unsigned) |  |  |
| BGH                                            | 0x46   | Branch on greater than halfword (signed)            |  |  |
| BGUB                                           | 0x57   | Branch on greater than byte (unsigned)              |  |  |
| BGUH                                           | 0x56   | Branch on greater than halfword (unsigned)          |  |  |
| BITB                                           | 0x3B   | Bit test byte                                       |  |  |
| BITH                                           | 0x3A   | Bit test halfword                                   |  |  |
| BITW                                           | 0x38   | Bit test word                                       |  |  |
| BLB                                            | 0x4B   | Branch on less than byte (signed)                   |  |  |
| BLEB                                           | 0x4F   | Branch on less than or equal byte (signed)          |  |  |
| BLEH                                           | 0x4E   | Branch on less than or equal halfword (signed)      |  |  |

\* Indicates that opcode matches another instruction mnemonic with the same operation.

## WE 32100 MICROPROCESSOR INSTRUCTION SET Instruction Set Summary by Mnemonic

| MnemonicOpcodeInstructionBLEUB0x5FBranch on less than or equal byte (unsigned)BLEUH0x5EBranch on less than or equal halfword (unsigned)BLH0x4ABranch on less than balfword (unsigned)BLUB0x58*Branch on less than byte (unsigned)BLUH0x5A*Branch on less than byte (duplicate)BNEB0x67Branch on not equal byte (duplicate)BNEB0x77Branch on not equal halfword (duplicate)BNEH0x66Branch on not equal halfword (duplicate)BNEH0x76Branch on not equal halfword (duplicate)BNEH0x77Branch on not equal halfword (duplicate)BNEH0x78Branch on not equal halfword (duplicate)BRB0x78Branch with byte (8-bit) displacementBRB0x78Branch to subroutine, byte displacementBSBH0x37Branch to subroutine, byte displacementBVCB0x63Branch on overflow clear, byte displacementBVCB0x63Branch on overflow set, halfword displacementBVSB0x63Branch on overflow set, halfword displacementBVSB0x68Branch on overflow set, halfword displacementCALL0x2CCall procedureCFLUSH0x37Cache flushCLRB0x38Clear byteCLRB0x37Compare byteCLRH0x32Clear byteDYH0x35Compare byteCLRH0x37Decrement byteDECB0x97Decrement byte <tr< th=""><th colspan="4">Table A-9. Instruction Set Summary by Mnemonic (Continued)</th></tr<> | Table A-9. Instruction Set Summary by Mnemonic (Continued) |        |                                                  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|--------|--------------------------------------------------|--|
| BLEUB0x5FBranch on less than or equal byte (unsigned)BLEUH0x5EBranch on less than or equal halfword (unsigned)BLU0x5A*Branch on less than byte (unsigned)BLUB0x5A*Branch on less than byte (unsigned)BLUH0x5A*Branch on not equal byte (duplicate)BNEB0x77Branch on not equal byte (duplicate)BNEH0x66Branch on not equal halfword (duplicate)BNEH0x76Branch on not equal halfword (duplicate)BNEH0x76Branch on not equal halfword (duplicate)BNEH0x76Branch on not equal halfword (duplicate)BRB0x77Branch on not equal halfword (duplicate)BRB0x78Branch on ut equal halfword (losplacementBRH0x76Branch on utequal halfword (losplacementBSBH0x37Branch to subroutine, byte displacementBVCB0x63Branch on overflow clear, halfword displacementBVCH0x62Branch on overflow set, halfword displacementBVSB0x68Branch on overflow set, halfword displacementBVSH0x6ABranch on overflow set, halfword displacementCALL0x2CCall procedureCFLUSH0x37Cache flushCLRB0x38Clear byteCLRH0x32Clear byteCLRH0x32Clear byteCLRH0x36Compare byteCLRH0x37Decrement byteDECH0x97Decrement byteDECH0x96Decrement byte <t< th=""><th>Mnemonic</th><th>Opcode</th><th>Instruction</th></t<>                             | Mnemonic                                                   | Opcode | Instruction                                      |  |
| BLEUH0x5EBranch on less than or equal halfword (unsigned)BLH0x4ABranch on less than halfword (unsigned)BLUB0x5A*Branch on less than halfword (unsigned)BLUH0x5A*Branch on not equal byte (duplicate)BNEB0x67Branch on not equal byte (duplicate)BNEB0x77Branch on not equal halfword (duplicate)BNEH0x66Branch on not equal halfword (duplicate)BNEH0x76Branch on not equal halfwordBPT0x2EBreakpoint trapBR0x77Branch with byte (8-bit) displacementBRH0x7ABranch with halfword (16-bit) displacementBSB0x37Branch to subroutine, byte displacementBVCB0x63Branch on overflow clear, byte displacementBVCB0x63Branch on overflow clear, halfword displacementBVSB0x63Branch on overflow clear, halfword displacementBVSB0x6ABranch on overflow clear, halfword displacementBVSH0x6ABranch on overflow set, byte displacementBVSH0x6B             | BLEUB                                                      | 0x5F   | Branch on less than or equal byte (unsigned)     |  |
| BLH0x4ABranch on less than halfword (signed)BLUB0x5B*Branch on less than byte (unsigned)BLUH0x5A*Branch on less than balfword (unsigned)BNEB0x67Branch on not equal byte (duplicate)BNEB0x77Branch on not equal byte (duplicate)BNEH0x66Branch on not equal halfword (duplicate)BNEH0x76Branch on not equal halfword (duplicate)BNEH0x76Branch on not equal halfword (duplicate)BRB0x78Branch on not equal halfword (id-bit) displacementBRB0x77Branch with halfword (id-bit) displacementBSB0x73Branch to subroutine, byte displacementBSVB0x63Branch on overflow clear, byte displacementBVCB0x63Branch on overflow set, hyte displacementBVSB0x64Branch on overflow set, halfword displacementBVSH0x6ABranch on overflow set, halfword displacementBVSH0x6ABranch on overflow set, halfword displacementCLLB0x82Clear byteCLRH0x82Clear halfwordCLRW0x80Clear halfwordCMPH0x32Compare byteCMPH0x34Decrement byteDECH0x96Decrement wordDECH0x96Decrement wordDIVB20xAFDivide byteDIVB30xEFDivide byteDIVB40xACExtract field byteEXTFB0xCEExtract field byteDIVW20xACDivide wor                                                                                                                         | BLEUH                                                      | 0x5E   | Branch on less than or equal halfword (unsigned) |  |
| BLUB0x5B*Branch on less than byte (unsigned)BLUH0x5A*Branch on less than halfword (unsigned)BNEB0x67Branch on not equal byte (duplicate)BNEB0x77Branch on not equal halfword (duplicate)BNEH0x66Branch on not equal halfwordBNEH0x76Branch on not equal halfwordBPT0x2EBreakpoint trapBRB0x77Branch with byte (8-bit) displacementBRH0x7ABranch to subroutine, byte displacementBSBB0x37Branch to subroutine, halfword displacementBVCB0x63Branch on overflow clear, byte displacementBVCB0x63Branch on overflow clear, halfword displacementBVSB0x68Branch on overflow set, byte displacementBVSB0x68Branch on overflow set, halfword displacementBVSH0x6ABranch on overflow set, halfword displacementCLLL0x27Cache flushCLRW0x80Clear wordCLRW0x36Clear wordCLRW0x37Decrement byteOMPH0x37Compare wordDECB0x97Decrement byteDECH0x96Decrement wordDIVB20xAFDivide byte 3-addressDIVH30xEEDivide byte 3-addressDIVH30xECDivide wordDIVW20xACDivide wordDIVW30xEEDivide wordDIVW30xECExtract field byteEXTFH0xCCExtract field byte <td>BLH</td> <td>0x4A</td> <td>Branch on less than halfword (signed)</td>                                                                                            | BLH                                                        | 0x4A   | Branch on less than halfword (signed)            |  |
| BLUH0x5A*Branch on less than halfword (unsigned)BNEB0x67Branch on not equal byte (duplicate)BNEH0x66Branch on not equal byteBNEH0x76Branch on not equal halfword (duplicate)BNEH0x76Branch on not equal halfwordBPT0x2EBreakpoint trapBRB0x7ABranch with byte (8-bit) displacementBRH0x7ABranch to subroutine, byte displacementBSB0x37Branch to subroutine, byte displacementBVCB0x63Branch on overflow clear, byte displacementBVCB0x63Branch on overflow clear, byte displacementBVSH0x6ABranch on overflow set, halfword displacementBVSH0x6ABranch on overflow set, halfword displacementCALL0x2CCall procedureCFLUSH0x37Cache flushCLRB0x38Clear byteCLRH0x36Compare byteCMPH0x35Compare byteCMPH0x36Decrement byteDECB0x97Decrement byteDECH0x94Decrement wordDIVB20xAFDivide byteDIVH30xEFDivide byteDIVH30xEEDivide halfwordDIVW30xACExtract field byteEXTFB0xCFExtract field byteEXTFW0xCCExtract field halfwordEXTFW0xCCExtract field byte                                                                                                                                                                                                                                                    | BLUB                                                       | 0x5B*  | Branch on less than byte (unsigned)              |  |
| BNEB0x67Branch on not equal byte (duplicate)BNEB0x77Branch on not equal halfword (duplicate)BNEH0x66Branch on not equal halfwordBNEH0x76Branch on not equal halfwordBNEH0x76Branch on not equal halfwordBPT0x2EBreakpoint trapBRB0x7BBranch with byte (8-bit) displacementBRB0x7ABranch with halfword (16-bit) displacementBSB0x37Branch to subroutine, byte displacementBVCB0x63Branch on overflow clear, byte displacementBVCB0x63Branch on overflow clear, halfword displacementBVSB0x68Branch on overflow clear, halfword displacementBVSB0x68Branch on overflow set, byte displacementBVSB0x68Branch on overflow set, byte displacementBVSH0x6ABranch on overflow set, halfword displacementBVSH0x6ABranch on overflow set, halfword displacementBVSH0x6ABranch on overflow set, halfword displacementCALL0x2CCall procedureCFLUSH0x27Cache flushCLRB0x38Clear byteCLRW0x30Clear wordCMPB0x37Decrement byteDECB0x97Decrement byteDECH0x96Decrement wordDIVB20xAFDivide byte 3-addressDIVH20xAFDivide byte 3-addressDIVH30xEEDivide halfwordDIVW30xEEDivide word <t< td=""><td>BLUH</td><td>0x5A*</td><td>Branch on less than halfword (unsigned)</td></t<>                                          | BLUH                                                       | 0x5A*  | Branch on less than halfword (unsigned)          |  |
| BNEB0x77Branch on not equal byteBNEH0x66Branch on not equal halfword (duplicate)BNEH0x76Branch on not equal halfwordBPT0x2EBreakpoint trapBRB0x7BBranch with byte (8-bit) displacementBRH0x7ABranch to subroutine, byte displacementBSBB0x37Branch to subroutine, halfword displacementBVCB0x63Branch on overflow clear, byte displacementBVCB0x63Branch on overflow clear, halfword displacementBVSB0x68Branch on overflow clear, halfword displacementBVSB0x68Branch on overflow set, byte displacementBVSH0x6ABranch on overflow set, halfword displacementCLLB0x83Clear byteCLRB0x83Clear byteCLRH0x82Clear byteCMPH0x36Compare byteCMPH0x36Decrement byteDECB0x97Decrement byteDECH0x94Decrement wordDIVB20xAFDivide byteDIVB30xEFDivide byte 3-addressDIVH20xAEDivide word, 3-addressDIVW20xACDivide wordDIVW30xEEDivide wordDIVW30xEEDivide wordEXTFH0xCEExtract field halfwordEXTFW0xCCExtract field wordEXTFW0xCCExtract field word                                                                                                                                                                                                                                                             | BNEB                                                       | 0x67   | Branch on not equal byte (duplicate)             |  |
| BNEH0x66Branch on not equal halfword (duplicate)BNEH0x76Branch on not equal halfwordBPT0x2EBreakpoint trapBRB0x7BBranch with byte (8-bit) displacementBRH0x7ABranch with halfword (16-bit) displacementBSBB0x37Branch to subroutine, byte displacementBSBH0x36Branch to subroutine, halfword displacementBVCB0x63Branch on overflow clear, byte displacementBVSB0x6ABranch on overflow set, byte displacementBVSH0x6ABranch on overflow set, halfword displacementCALL0x2CCall procedureCFUSH0x83Clear byteCLRH0x82Clear byteCLRW0x80Clear wordCMPB0x37Decrement byteDECB0x97Decrement byteDECB0x97Decrement byteDECH0x94Decrement wordDIVB30xEFDivide byte 3-addressDIVH20xACDivide byte 3-addressDIVH30xEFDivide word, 3-addressDIVW30xECDivide wordDIVW30xECDivide wordDIVW30xEFDivide wordDIVW40xCCExtract field halfwordEXTFH0xCCExtract field halfwordEXTFW0xCCExtract field halfword                                                                                                                                                                                                                                                                                                              | BNEB                                                       | 0x77   | Branch on not equal byte                         |  |
| BNEH0x76Branch on not equal halfwordBPT0x2EBreakpoint trapBRB0x7BBranch with byte (8-bit) displacementBRH0x7ABranch with halfword (16-bit) displacementBSBB0x37Branch to subroutine, byte displacementBSBH0x36Branch to subroutine, halfword displacementBVCB0x63Branch on overflow clear, byte displacementBVCB0x62Branch on overflow set, byte displacementBVSB0x6ABranch on overflow set, byte displacementBVSH0x6ABranch on overflow set, halfword displacementCALL0x2CCall procedureCFLUSH0x27Cache flushCLRB0x3FClear byteCLRW0x3CCompare byteCMPB0x3FCompare byteCMPH0x3CCompare byteDECH0x97Decrement byteDECH0x94Decrement wordDIVB20xAFDivide byteDIVB30xEFDivide byteDIVH20xACDivide halfwordDIVH30xEEDivide halfwordDIVW30xECDivide wordDIVW30xECDivide wordDIVW30xECDivide wordEXTFH0xCEExtract field byteEXTFW0xCCExtract field wordEXTFW0xCCExtract field word                                                                                                                                                                                                                                                                                                                            | BNEH                                                       | 0x66   | Branch on not equal halfword (duplicate)         |  |
| BPT0x2EBreakpoint trapBRB0x7BBranch with byte (8-bit) displacementBRH0x7ABranch with halfword (16-bit) displacementBSBB0x37Branch to subroutine, byte displacementBSBH0x36Branch to subroutine, halfword displacementBVCB0x63Branch on overflow clear, byte displacementBVCH0x62Branch on overflow set, byte displacementBVSB0x6ABranch on overflow set, byte displacementBVSH0x6ABranch on overflow set, byte displacementCALL0x2CCall procedureCFLUSH0x27Cache flushCLRB0x83Clear byteCLRH0x82Clear byteCLRW0x80Clear wordCMPB0x37Compare byteCMPH0x32Compare byteCMPH0x32Compare wordDECB0x97Decrement byteDECH0x96Decrement wordDIVB20xAFDivide byte 3-addressDIVH20xAEDivide halfword, 3-addressDIVH30xEEDivide halfwordDIVW30xECDivide wordDIVW30xECDivide wordDIVW30xEFExtract field byteEXTFB0xCEExtract field wordEXTFW0xCCExtract field wordEXTOP0x14Extended opcode                                                                                                                                                                                                                                                                                                                           | BNEH                                                       | 0x76   | Branch on not equal halfword                     |  |
| BRB<br>BRH0x7BBranch with byte (8-bit) displacementBRH0x7ABranch with halfword (16-bit) displacementBSBB0x37Branch to subroutine, byte displacementBSBH0x36Branch to subroutine, halfword displacementBVCB0x63Branch on overflow clear, byte displacementBVCH0x62Branch on overflow clear, halfword displacementBVSB0x6ABranch on overflow set, byte displacementBVSH0x6ABranch on overflow set, halfword displacementBVSH0x6ABranch on overflow set, halfword displacementCALL0x2CCall procedureCFLUSH0x27Cache flushCLRB0x83Clear byteCLRW0x80Clear wordCMPB0x35Compare byteCMPH0x32Compare byteCMPW0x32Compare wordDECB0x97Decrement byteDECH0x96Decrement wordDIVB20xAFDivide byte 3-addressDIVH20xAEDivide halfwordDIVH30xEEDivide wordDIVW30xECDivide wordDIVW30xECDivide wordDIVW30xECDivide wordEXTFH0xCCExtract field byteEXTFW0xCCExtract field wordEXTOP0x14Extended opcode                                                                                                                                                                                                                                                                                                                   | BPT                                                        | 0x2E   | Breakpoint trap                                  |  |
| BRH0x7ABranch with halfword (16-bit) displacementBSBB0x37Branch to subroutine, byte displacementBSBH0x36Branch to subroutine, halfword displacementBVCB0x63Branch on overflow clear, byte displacementBVCH0x62Branch on overflow clear, halfword displacementBVSB0x6ABranch on overflow set, byte displacementBVSH0x6ABranch on overflow set, halfword displacementBVSH0x6ABranch on overflow set, halfword displacementCALL0x2CCall procedureCFLUSH0x27Cache flushCLRB0x83Clear byteCLRH0x82Clear halfwordCLRW0x80Clear wordCMPB0x37Compare byteCMPH0x32Compare byteCMPH0x32Compare halfwordDECB0x97Decrement byteDECH0x94Decrement wordDIVB20xAFDivide byte 3-addressDIVH30xEFDivide halfwordDIVW20xACDivide wordDIVW30xECDivide wordDIVW30xECDivide wordDIVW30xECDivide wordDIVW30xECExtract field byteEXTFW0xCCExtract field wordEXTOP0x14Extended opcode                                                                                                                                                                                                                                                                                                                                            | BRB                                                        | 0x7B   | Branch with byte (8-bit) displacement            |  |
| BSBB0x37Branch to subroutine, byte displacementBSBH0x36Branch to subroutine, halfword displacementBVCB0x63Branch on overflow clear, byte displacementBVCH0x62Branch on overflow clear, halfword displacementBVSB0x68Branch on overflow set, byte displacementBVSH0x6ABranch on overflow set, halfword displacementCALL0x2CCall procedureCFLUSH0x27Cache flushCLRB0x83Clear byteCLRH0x82Clear byteCLRW0x80Clear wordCMPB0x3FCompare byteCMPH0x3ECompare byteCMPW0x3CCompare wordDECB0x97Decrement byteDECW0x94Decrement wordDIVB20xAFDivide byte 3-addressDIVH20xAEDivide halfwordDIVH30xEEDivide halfwordDIVW30xECDivide wordDIVW30xECDivide wordDIVW30xECDivide wordDIVW30xECDivide wordDIVW30xECDivide wordDIVW30xECDivide wordDIVW30xECDivide wordEXTFB0xCFExtract field byteEXTFW0xCCExtract field wordEXTOP0x14Extended opcode                                                                                                                                                                                                                                                                                                                                                                      | BRH                                                        | 0x7A   | Branch with halfword (16-bit) displacement       |  |
| BSBH0x36Branch to subroutine, halfword displacementBVCB0x63Branch on overflow clear, byte displacementBVCH0x62Branch on overflow clear, halfword displacementBVSB0x6BBranch on overflow set, byte displacementBVSH0x6ABranch on overflow set, halfword displacementCALL0x2CCall procedureCFLUSH0x27Cache flushCLRB0x83Clear byteCLRH0x82Clear halfwordCLRW0x80Clear wordCMPB0x3FCompare byteCMPH0x3CCompare halfwordDECB0x97Decrement byteDECH0x96Decrement wordDIVB20xAFDivide byteDIVB30xEFDivide byteDIVH20xACDivide halfwordDIVW20xACDivide wordDIVW30xECDivide wordDIVW30xECDivide wordDIVW30xECDivide wordDIVW30xECDivide wordDIVW30xECDivide wordDIVW30xECDivide wordDIVW30xECDivide wordDIVW40xCEExtract field halfwordEXTFW0xCCExtract field wordEXTOP0x14Extended opcode                                                                                                                                                                                                                                                                                                                                                                                                                       | BSBB                                                       | 0x37   | Branch to subroutine, byte displacement          |  |
| BVCB0x63Branch on overflow clear, byte displacementBVCH0x62Branch on overflow clear, halfword displacementBVSB0x6BBranch on overflow set, byte displacementBVSH0x6ABranch on overflow set, byte displacementCALL0x2CCall procedureCFLUSH0x27Cache flushCLRB0x83Clear byteCLRH0x82Clear halfwordCLRW0x80Clear wordCMPB0x3FCompare byteCMPH0x3CCompare halfwordCMPW0x3CCompare wordDECB0x97Decrement byteDECH0x94Decrement wordDIVB20xAFDivide byteDIVB30xEFDivide byteDIVH20xACDivide halfwordDIVW20xACDivide wordDIVW30xEEDivide wordDIVW20xACDivide wordDIVW30xECExtract field byteEXTFB0xCFExtract field wordEXTFW0xCCExtract field wordEXTOP0x14Extended opcode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | BSBH                                                       | 0x36   | Branch to subroutine, halfword displacement      |  |
| BVCH0x62Branch on overflow clear, halfword displacementBVSB0x6ABranch on overflow set, byte displacementBVSH0x6ABranch on overflow set, halfword displacementCALL0x2CCall procedureCFLUSH0x27Cache flushCLRB0x83Clear byteCLRH0x82Clear halfwordCLRW0x80Clear wordCMPB0x3FCompare byteCMPH0x3CCompare byteCMPW0x3CCompare halfwordDECB0x97Decrement byteDECH0x94Decrement wordDIVB20xAFDivide byteDIVB30xEFDivide byteDIVH20xACDivide halfwordDIVW20xACDivide wordDIVW30xEFDivide wordEXTFB0xCFExtract field byteEXTOP0x14Extended opcode                                                                                                                                                                                                                                                                                                                                                                                            | BVCB                                                       | 0x63   | Branch on overflow clear, byte displacement      |  |
| BVSB0x6BBranch on overflow set, byte displacementBVSH0x6ABranch on overflow set, halfword displacementCALL0x2CCall procedureCFLUSH0x27Cache flushCLRB0x83Clear byteCLRH0x82Clear halfwordCLRW0x80Clear wordCMPB0x3FCompare byteCMPH0x3ECompare halfwordCMPW0x3CCompare wordDECB0x97Decrement byteDECH0x96Decrement wordDIVB20xAFDivide byteDIVB30xEFDivide byte 3-addressDIVH20xACDivide halfword, 3-addressDIVW20xACDivide wordDIVW30xEEDivide wordDIVW30xCFExtract field byteEXTFB0xCCExtract field wordEXTOP0x14Extended opcode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | BVCH                                                       | 0x62   | Branch on overflow clear, halfword displacement  |  |
| BVSH0x6ABranch on overflow set, halfword displacementCALL0x2CCall procedureCFLUSH0x27Cache flushCLRB0x83Clear byteCLRH0x82Clear halfwordCLRW0x80Clear wordCMPB0x3FCompare byteCMPH0x3CCompare halfwordCMPW0x3CCompare wordDECB0x97Decrement byteDECH0x96Decrement wordDIVB20xAFDivide byteDIVB30xEFDivide byte 3-addressDIVH20xACDivide halfwordDIVH30xEEDivide wordDIVW20xACDivide wordDIVW30xECDivide wordDIVW30xECDivide wordDIVW30xECDivide wordDIVW30xEFExtract field byteEXTFB0xCFExtract field wordEXTFW0xCCExtract field wordEXTOP0x14Extended opcode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | BVSB                                                       | 0x6B   | Branch on overflow set, byte displacement        |  |
| CALL0x2CCall procedureCFLUSH0x27Cache flushCLRB0x83Clear byteCLRH0x82Clear halfwordCLRW0x80Clear wordCMPB0x3FCompare byteCMPH0x3ECompare halfwordCMPW0x3CCompare wordDECB0x97Decrement byteDECH0x96Decrement wordDIVB20xAFDivide byteDIVB30xEFDivide byte 3-addressDIVH20xAAEDivide halfword, 3-addressDIVW20xACDivide wordDIVW30xECDivide wordDIVW30xEFDivide wordDIVW30xCFExtract field byteEXTFB0xCFExtract field wordEXTFW0xACExtract field wordEXTOP0x14Extended opcode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | BVSH                                                       | 0x6A   | Branch on overflow set, halfword displacement    |  |
| CFLUSH0x27Cache flushCLRB0x83Clear byteCLRH0x82Clear halfwordCLRW0x80Clear wordCMPB0x3FCompare byteCMPH0x3ECompare halfwordCMPW0x3CCompare wordDECB0x97Decrement byteDECH0x96Decrement halfwordDECW0x94Decrement wordDIVB20xAFDivide byteDIVB30xEFDivide byte 3-addressDIVH20xACDivide halfword, 3-addressDIVW20xACDivide wordDIVW30xECDivide word, 3-addressDIVW30xEFDivide word, 3-addressDIVW30xECDivide word, 3-addressDIVW30xECDivide word, 3-addressEXTFB0xCFExtract field byteEXTFW0xCCExtract field wordEXTFW0xCCExtract field wordEXTFW0x14Extended opcode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | CALL                                                       | 0x2C   | Call procedure                                   |  |
| CLRB0x83Clear byteCLRH0x82Clear halfwordCLRW0x80Clear wordCMPB0x3FCompare byteCMPH0x3ECompare halfwordCMPW0x3CCompare wordDECB0x97Decrement byteDECH0x96Decrement halfwordDECW0x3FDivide byteDIVB20xAFDivide byteDIVB30xEFDivide byte 3-addressDIVH20xACDivide halfwordDIVH30xEEDivide wordDIVW20xACDivide wordDIVW30xECDivide wordDIVW30xECDivide wordDIVW30xECDivide wordDIVW30xECDivide wordDIVW30xCFExtract field byteEXTFB0xCEExtract field wordEXTFW0xCCExtract field wordEXTFW0xCCExtract field wordEXTFW0xCCExtract field wordEXTFW0xCCExtract field wordEXTOP0x14Extended opcode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | CFLUSH                                                     | 0x27   | Cache flush                                      |  |
| CLRH0x82Clear halfwordCLRW0x80Clear wordCMPB0x3FCompare byteCMPH0x3ECompare halfwordCMPW0x3CCompare wordDECB0x97Decrement byteDECH0x96Decrement halfwordDECW0x3FDivide byteDIVB20xAFDivide byteDIVB30xEFDivide byte 3-addressDIVH20xAAEDivide halfwordDIVH30xEEDivide wordDIVW20xACDivide wordDIVW30xECDivide wordDIVW30xECDivide wordDIVW30xCFExtract field byteEXTFB0xCEExtract field wordEXTFW0xCCExtract field wordEXTFW0xCCExtract field wordEXTFW0xACDivide wordDXCEExtract field halfwordEXTFW0xCCExtract field wordEXTFW0xCCExtract field wordEXTFW0xCCExtract field wordEXTFW0xCCExtract field wordEXTFW0xCCExtract field wordEXTFW0xCCExtract field wordEXTOP0x14Extended opcode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | CLRB                                                       | 0x83   | Clear byte                                       |  |
| CLRW0x80Clear wordCMPB0x3FCompare byteCMPH0x3ECompare halfwordCMPW0x3CCompare wordDECB0x97Decrement byteDECH0x96Decrement halfwordDECW0x94Decrement wordDIVB20xAFDivide byteDIVB30xEFDivide byte 3-addressDIVH20xACDivide halfwordDIVH30xEEDivide halfword, 3-addressDIVW20xACDivide wordDIVW30xECDivide wordDIVW30xECDivide wordDIVW30xCFExtract field byteEXTFB0xCCExtract field wordEXTFW0xCCExtract field wordEXTFW0x14Extended opcode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | CLRH                                                       | 0x82   | Clear halfword                                   |  |
| CMPB0x3FCompare byteCMPH0x3ECompare halfwordCMPW0x3CCompare wordDECB0x97Decrement byteDECH0x96Decrement halfwordDECW0x94Decrement wordDIVB20xAFDivide byteDIVB30xEFDivide byte 3-addressDIVH20xAEDivide halfwordDIVH30xEEDivide halfword, 3-addressDIVW20xACDivide wordDIVW30xECDivide word, 3-addressEXTFB0xCFExtract field byteEXTFW0xCCExtract field wordEXTFW0xCCExtract field wordEXTFW0x14Extended opcode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | CLRW                                                       | 0x80   | Clear word                                       |  |
| CMPH0x3ECompare halfwordCMPW0x3CCompare wordDECB0x97Decrement byteDECH0x96Decrement halfwordDECW0x94Decrement wordDIVB20xAFDivide byteDIVB30xEFDivide byte 3-addressDIVH20xAEDivide halfwordDIVH30xEEDivide halfword, 3-addressDIVW20xACDivide wordDIVW30xECDivide word, 3-addressEXTFB0xCFExtract field byteEXTFW0xCCExtract field wordEXTFW0xCCExtract field wordEXTOP0x14Extended opcode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | СМРВ                                                       | 0x3F   | Compare byte                                     |  |
| CMPW0x3CCompare wordDECB0x97Decrement byteDECH0x96Decrement halfwordDECW0x94Decrement wordDIVB20xAFDivide byteDIVB30xEFDivide byte 3-addressDIVH20xAEDivide halfwordDIVH30xEEDivide halfword, 3-addressDIVW20xACDivide wordDIVW30xECDivide word, 3-addressEXTFB0xCFExtract field byteEXTFH0xCCExtract field wordEXTFW0xCCExtract field word                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | СМРН                                                       | 0x3E   | Compare halfword                                 |  |
| DECB0x97Decrement byteDECH0x96Decrement halfwordDECW0x94Decrement wordDIVB20xAFDivide byteDIVB30xEFDivide byte 3-addressDIVH20xAEDivide halfwordDIVH30xEEDivide halfword, 3-addressDIVW20xACDivide wordDIVW30xECDivide word, 3-addressEXTFB0xCFExtract field byteEXTFW0xCCExtract field wordEXTFW0x14Extended opcode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | CMPW                                                       | 0x3C   | Compare word                                     |  |
| DECH0x96Decrement halfwordDECW0x94Decrement wordDIVB20xAFDivide byteDIVB30xEFDivide byte 3-addressDIVH20xAEDivide halfwordDIVH30xEEDivide halfword, 3-addressDIVW20xACDivide wordDIVW30xECDivide word, 3-addressEXTFB0xCFExtract field byteEXTFH0xCCExtract field wordEXTFW0xCCExtract field wordEXTOP0x14Extended opcode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | DECB                                                       | 0x97   | Decrement byte                                   |  |
| DECW0x94Decrement wordDIVB20xAFDivide byteDIVB30xEFDivide byte 3-addressDIVH20xAEDivide halfwordDIVH30xEEDivide halfword, 3-addressDIVW20xACDivide wordDIVW30xECDivide word, 3-addressEXTFB0xCFExtract field byteEXTFH0xCCExtract field wordEXTFW0xCCExtract field wordEXTFW0xCCExtract field word                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | DECH                                                       | 0x96   | Decrement halfword                               |  |
| DIVB20xAFDivide byteDIVB30xEFDivide byte 3-addressDIVH20xAEDivide halfwordDIVH30xEEDivide halfword, 3-addressDIVW20xACDivide wordDIVW30xECDivide word, 3-addressEXTFB0xCFExtract field byteEXTFH0xCCExtract field wordEXTFW0xCCExtract field wordEXTFW0xACDivide word                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | DECW                                                       | 0x94   | Decrement word                                   |  |
| DIVB30xEFDivide byte 3-addressDIVH20xAEDivide halfwordDIVH30xEEDivide halfword, 3-addressDIVW20xACDivide wordDIVW30xECDivide word, 3-addressEXTFB0xCFExtract field byteEXTFH0xCEExtract field halfwordEXTFW0xCCExtract field word                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | DIVB2                                                      | 0xAF   | Divide byte                                      |  |
| DIVH20xAEDivide halfwordDIVH30xEEDivide halfword, 3-addressDIVW20xACDivide wordDIVW30xECDivide word, 3-addressEXTFB0xCFExtract field byteEXTFH0xCEExtract field halfwordEXTFW0xCCExtract field wordEXTFW0xCCExtract field word                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | DIVB3                                                      | 0xEF   | Divide byte 3-address                            |  |
| DIVH30xEEDivide halfword, 3-addressDIVW20xACDivide wordDIVW30xECDivide word, 3-addressEXTFB0xCFExtract field byteEXTFH0xCEExtract field halfwordEXTFW0xCCExtract field wordEXTOP0x14Extended opcode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | DIVH2                                                      | 0xAE   | Divide halfword                                  |  |
| DIVW2<br>DIVW30xAC<br>0xECDivide word<br>Divide word, 3-addressEXTFB<br>EXTFH0xCFExtract field byte<br>Extract field halfword<br>EXTFWEXTFW0xCCExtract field wordEXTOP0x14Extended opcode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | DIVH3                                                      | 0xEE   | Divide halfword, 3-address                       |  |
| DIVW30xECDivide word, 3-addressEXTFB0xCFExtract field byteEXTFH0xCEExtract field halfwordEXTFW0xCCExtract field wordEXTOP0x14Extended opcode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | DIVW2                                                      | 0xAC   | Divide word                                      |  |
| EXTFB0xCFExtract field byteEXTFH0xCEExtract field halfwordEXTFW0xCCExtract field wordEXTOP0x14Extended opcode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | DIVW3                                                      | 0xEC   | Divide word, 3-address                           |  |
| EXTFH0xCEExtract field halfwordEXTFW0xCCExtract field wordEXTOP0x14Extended opcode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | EXTFB                                                      | 0xCF   | Extract field byte                               |  |
| EXTFW0xCCExtract field wordEXTOP0x14Extended opcode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | EXTFH                                                      | 0xCE   | Extract field halfword                           |  |
| EXTOP 0x14 Extended opcode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | EXTFW                                                      | 0xCC   | Extract field word                               |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | EXTOP                                                      | 0x14   | Extended opcode                                  |  |

\* Indicates that opcode matches another instruction mnemonic with the same operation.

.

| Table A-9. In | struction Set | Summary by Mnemonic (Continued) |
|---------------|---------------|---------------------------------|
| Mnemonic      | Opcode        | Instruction                     |
| INCB          | 0x93          | Increment byte                  |
| INCH          | 0x92          | Increment halfword              |
| INCW          | 0x90          | Increment word                  |
| INSFB         | 0xCB          | Insert field byte               |
| INSFH         | 0xCA          | Insert field halfword           |
| INSFW         | 0xC8          | Insert field word               |
| JMP           | 0x24          | Jump                            |
| JSB           | 0x34          | Jump to subroutine              |
| LLSB3         | 0xD3          | Logical left shift byte         |
| LLSH3         | 0xD2          | Logical left shift halfword     |
| LLSW3         | 0xD0          | Logical left shift word         |
| LRSW3         | 0xD4          | Logical right shift word        |
| МСОМВ         | 0x8B          | Move complemented byte          |
| мсомн         | 0x8A          | Move complemented halfword      |
| MCOMW         | 0x88          | Move complemented word          |
| MNEGB         | 0x8F          | Move negated byte               |
| MNEGH         | 0x8E          | Move negated halfword           |
| MNEGW         | 0x8C          | Move negated word               |
| MODB2         | 0xA7          | Modulo byte                     |
| MODB3         | 0xE7          | Modulo byte, 3-address          |
| MODH2         | 0xA6          | Modulo halfword                 |
| MODH3         | 0xE6          | Modulo halfword, 3-address      |
| MODW2         | 0xA4          | Modulo word                     |
| MODW3         | 0xE4          | Modulo word, 3-address          |
| MOVAW         | 0x04          | Move address (word)             |
| MOVB          | 0x87          | Move byte                       |
| MOVBLW        | 0x3019        | Move block of words             |
| MOVH          | 0x86          | Move halfword                   |
| MOVW          | 0x84          | Move word                       |
| MULB2         | 0xAB          | Multiply byte                   |
| MULB3         | OxEB          | Multiply byte, 3-address        |
| MULH2         | OxAA          | Multiply halfword               |
| MULH3         | OxEA          | Multiply halfword, 3-address    |
| MULW2         | UXA8          | Multiply word                   |
| MULW3         | UxE8          | Multiply word, 3-address        |
| MVERNO        | 0x3009        | Move version number             |
| NOP           | 0x70          | No operation, 1 byte            |
| NOP2          | 0x73          | No operation, 2 bytes           |
| NOP3          | 0x72          | No operation, 3 bytes           |
| ORB2          | 0xB3          | OR byte                         |
| ORB3          | 0xF3          | OR byte, 3-address              |
| ORH2          | 0xB2          | OR halfword                     |
| ORH3          | UxF2          | OR haltword, 3-address          |
| ORW2          | UXB0          | OR word                         |
| ORW3          | 0xF0          | OR word, 3-address              |

## WE 32100 MICROPROCESSOR INSTRUCTION SET Instruction Set Summary by Mnemonic

| Table A-9. | Instruction | on Set Summary by Mnemonic (Continued)     |
|------------|-------------|--------------------------------------------|
| Mnemonic   | Opcode      | Instruction                                |
| POPW       | 0x20        | Pop word                                   |
| PUSHAW     | 0xE0        | Push address word                          |
| PUSHW      | 0xA0        | Push word                                  |
| RCC        | 0x50*       | Return on carry clear                      |
| RCS        | 0x58*       | Return on carry set                        |
| REQLU      | 0x6C        | Return on equal (unsigned)                 |
| REQL       | 0x7C        | Return on equal (signed)                   |
| RESTORE    | 0x18        | Restore registers                          |
| RET        | 0x08        | Return from procedure                      |
| RGEQ       | 0x40        | Return on greater than or equal (signed)   |
| RGEQU      | 0x50*       | Return on greater than or equal (unsigned) |
| RGTR       | 0x44        | Return on greater than (signed)            |
| RGTRU      | 0x54        | Return on greater than (unsigned)          |
| RLEQ       | 0x4C        | Return on less than or equal (signed)      |
| RLEQU      | 0x5C        | Return on less than or equal (unsigned)    |
| RLSS       | 0x48        | Return on less than (signed)               |
| RLSSU      | 0x58*       | Return on less than (unsigned)             |
| RNEQU      | 0x64        | Return on not equal (unsigned)             |
| RNEQ       | 0x74        | Return on not equal (signed)               |
| ROTW       | 0xD8        | Rotate word                                |
| RSB        | 0x78        | Return from subroutine                     |
| RVC        | 0x60        | Return on overflow clear                   |
| RVS        | 0x68        | Return on overflow set                     |
| SAVE       | 0x10        | Save registers                             |
| SPOP       | 0x32        | Coprocessor operation                      |
| SPOPRS     | 0x22        | Coprocessor operation read single          |
| SPOPRD     | 0x02        | Coprocessor operation read double          |
| SPOPRT     | 0x06        | Coprocessor operation read triple          |
| SPOPS2     | 0x23        | Coprocessor operation single 2-address     |
| SPOPD2     | 0x03        | Coprocessor operation double 2-address     |
| SPOPT2     | 0x07        | Coprocessor operation triple 2-address     |
| SPOPWS     | 0x33        | Coprocessor operation write single         |
| SPOPWD     | 0x13        | Coprocessor operation write double         |
| SPOPWT     | 0x17        | Coprocessor operation write triple         |
| STRCPY     | 0x3035      | String copy                                |
| STREND     | 0x301F      | String end                                 |

\* Indicates that opcode matches another instruction mnemonic with the same operation.

| Table A-9. | Instruction S | et Summary by Mnemonic (Continued) |
|------------|---------------|------------------------------------|
| Mnemonic   | Opcode        | Instruction                        |
| SUBB2      | 0xBF          | Subtract byte                      |
| SUBB3      | 0xFF          | Subtract byte, 3-address           |
| SUBH2      | 0xBE          | Subtract halfword                  |
| SUBH3      | 0xFE          | Subtract halfword, 3-address       |
| SUBW2      | 0xBC          | Subtract word                      |
| SUBW3      | 0xFC          | Subtract word, 3-address           |
| SWAPBI     | 0x1F          | Swap byte interlocked              |
| SWAPHI     | 0x1E          | Swap halfword interlocked          |
| SWAPWI     | 0x1C          | Swap word interlocked              |
| TSTB       | 0x2B          | Test byte                          |
| TSTH       | 0x2A          | Test halfword                      |
| TSTW       | 0x28          | Test word                          |
| XORB2      | 0xB7          | Exclusive OR byte                  |
| XORB3      | 0xF7          | Exclusive OR byte, 3-address       |
| XORH2      | 0xB6          | Exclusive OR halfword              |
| XORH3      | 0xF6          | Exclusive OR halfword, 3-address   |
| XORW2      | 0xB4          | Exclusive OR word                  |
| XORW3      | 0xF4          | Exclusive OR word, 3-address       |

## A.5 Instruction Set Summary by Opcode

| Table A-10. In |        | struction Set Summary by Opcode         |
|----------------|--------|-----------------------------------------|
| Mnemonic       | Opcode | Instruction                             |
| SPOPRD         | 0x02   | Coprocessor operation read double       |
| SPOPD2         | 0x03   | Coprocessor operation double, 2-address |
| MOVAW          | 0x04   | Move address (word)                     |
| SPOPRT         | 0x06   | Coprocessor operation read triple       |
| SPOPT2         | 0x07   | Coprocessor operation triple, 2-address |
| RET            | 0x08   | Return from procedure                   |
| SAVE           | 0x10   | Save registers                          |
| SPOPWD         | 0x13   | Coprocessor operation write double      |
| EXTOP          | 0x14   | Extended opcode                         |
| SPOPWT         | 0x17   | Coprocessor operation write triple      |
| RESTORE        | 0x18   | Restore registers                       |
| SWAPWI         | 0x1C   | Swap word interlocked                   |
| SWAPHI         | 0x1E   | Swap halfword interlocked               |
| SWAPBI         | 0x1F   | Swap byte interlocked                   |
| POPW           | 0x20   | Pop word                                |
| SPOPRS         | 0x22   | Coprocessor operation read single       |
| SPOPS2         | 0x23   | Coprocessor operation single, 2-address |
| JMP            | 0x24   | Jump                                    |
| CFLUSH         | 0x27   | Cache flush                             |
| TSTW           | 0x28   | Test word                               |
| TSTH           | 0x2A   | Test halfword                           |
| TSTB           | 0x2B   | Test byte                               |
| CALL           | 0x2C   | Call procedure                          |
| BPT            | 0x2E   | Breakpoint trap                         |
| MVERNO         | 0x3009 | Move version number                     |
| MOVBLW         | 0x3019 | Move block of words                     |
| STREND         | 0x301F | String end                              |
| STRCPY         | 0x3035 | String copy                             |

| Table A-10. |        | Instruction Set Summary by Opcode (Continued)       |
|-------------|--------|-----------------------------------------------------|
| Mnemonic    | Opcode | Instruction                                         |
| SPOP        | 0x32   | Coprocessor operation                               |
| SPOPWS      | 0x33   | Coprocessor operation write single                  |
| JSB         | 0x34   | Jump to subroutine                                  |
| BSBH        | 0x36   | Branch to subroutine, halfword displacement         |
| BSBB        | 0x37   | Branch to subroutine, byte displacement             |
| BITW        | 0x38   | Bit test word                                       |
| BITH        | 0x3A   | Bit test halfword                                   |
| BITB        | 0x3B   | Bit test byte                                       |
| CMPW        | 0x3C   | Compare word                                        |
| СМРН        | 0x3E   | Compare halfword                                    |
| СМРВ        | 0x3F   | Compare byte                                        |
| RGEQ        | 0x40   | Return on greater than or equal (signed)            |
| BGEH        | 0x42   | Branch on greater than or equal halfword (signed)   |
| BGEB        | 0x43   | Branch on greater than or equal byte (signed)       |
| RGTR        | 0x44   | Return on greater than (signed)                     |
| BGH         | 0x46   | Branch on greater than halfword (signed)            |
| BGB         | 0x47   | Branch on greater than byte (signed)                |
| RLSS        | 0x48   | Return on less than (signed)                        |
| BLH         | 0x4A   | Branch on less than halfword (signed)               |
| BLB         | 0x4B   | Branch on less than byte (signed)                   |
| RLEQ        | 0x4C   | Return on less than or equal (signed)               |
| BLEH        | 0x4E   | Branch on less than or equal halfword (signed)      |
| BLEB        | 0x4F   | Ranch on less than or equal byte (signed)           |
| RCC         | 0x50*  | Return on carry clear                               |
| RGEQU       | 0x50*  | Return on greater than or equal (unsigned)          |
| BCCH        | 0x52*  | Branch on carry clear halfword                      |
| BGEUH       | 0x52*  | Branch on greater than or equal halfword (unsigned) |
| BCCB        | 0x53*  | Branch on carry clear byte                          |
| BGEUB       | 0x53*  | Branch on greater than or equal byte (unsigned)     |
| RGTRU       | 0x54   | Return on greater than (unsigned)                   |
| BGUH        | 0x56   | Branch on greater than halfword (unsigned)          |
| BGUB        | 0x57   | Branch on greater than byte (unsigned)              |
| RCS         | 0x58*  | Return on carry set                                 |
| RLSSU       | 0x58*  | Return on less than (unsigned)                      |
| BCSH        | 0x5A*  | Branch on carry set halfword                        |
| BLUH        | 0x5A*  | Branch on less than halfword (unsigned)             |
| BCSB        | 0x5B*  | Branch on carry set byte                            |
| BLUB        | 0x5B*  | Branch on less than byte (unsigned)                 |
| RLEQU       | 0x5C   | Return on less than or equal (unsigned)             |
| BLEUH       | 0x5E   | Branch on less than or equal halfword (unsigned)    |
| BLEUB       | 0x5F   | Branch on less than or equal byte (unsigned)        |

\* Indicates that opcode matches another instruction mnemonic with the same operation.

.

## WE 32100 MICROPROCESSOR INSTRUCTION SET Instruction Set Summary by Opcode

| Table A-10. Inst |        | truction Set Summary by Opcode (Continued)      |
|------------------|--------|-------------------------------------------------|
| Mnemonic         | Opcode | Instruction                                     |
| RVC              | 0x60   | Return on overflow clear                        |
| BVCH             | 0x62   | Branch on overflow clear, halfword displacement |
| BVCB             | 0x63   | Branch on overflow clear, byte displacement     |
| RNEQU            | 0x64   | Return on not equal (unsigned)                  |
| BNEH             | 0x66   | Branch on not equal halfword (duplicate)        |
| BNEB             | 0x67   | Branch on not equal byte (duplicate)            |
| RVS              | 0x68   | Return on overflow set                          |
| BVSH             | 0x6A   | Branch on overflow set, halfword displacement   |
| BVSB             | 0x6B   | Branch on overflow set, byte displacement       |
| REQLU            | 0x6C   | Return on equal (unsigned)                      |
| BEH              | 0x6E   | Branch on equal halfword (duplicate)            |
| BEB              | 0x6F   | Branch on equal byte (duplicate)                |
| NOP              | 0x70   | No operation, 1 byte                            |
| NOP3             | 0x72   | No operation, 3 bytes                           |
| NOP2             | 0x73   | No operation, 2 bytes                           |
| RNEQ             | 0x74   | Return on not equal (signed)                    |
| BNEH             | 0x76   | Branch on not equal halfword                    |
| BNEB             | 0x77   | Branch on not equal                             |
| RSB              | 0x78   | Return from subroutine                          |
| BRH              | 0x7A   | Branch with halfword (16-bit) displacement      |
| BRH              | 0x7B   | Branch with byte (8-bit) displacement           |
| REQL             | 0x7C   | Return on equal (signed)                        |
| BEH              | 0x7E   | Branch on equal halfword                        |
| BEB              | 0x7F   | Branch on equal byte                            |
| CLRW             | 0x80   | Clear word                                      |
| CLRH             | 0x82   | Clear halfword                                  |
| CLRB             | 0x83   | Clear byte                                      |
| MOVW             | 0x84   | Move word                                       |
| MOVH             | 0x86   | Move halfword                                   |
| MOVB             | 0x87   | Move byte                                       |
| MCOMW            | 0x88   | Move complemented word                          |
| МСОМН            | 0x8A   | Move complemented halfword                      |
| МСОМВ            | 0x8B   | Move complemented byte                          |
| MNEGW            | 0x8C   | Move negated word                               |
| MNEGH            | 0x8E   | Move negated halfword                           |
| MNEGB            | 0x8F   | Move negated byte                               |
| INCW             | 0x90   | Increment word                                  |
| INCH             | 0x92   | Increment halfword                              |
| INCB             | 0x93   | Increment byte                                  |
| DECW             | 0x94   | Decrement word                                  |
| DECH             | 0x96   | Decrement halfword                              |
| DECB             | 0x97   | Decrement byte                                  |
| ADDW2            | 0x9C   | Add word                                        |
| ADDH2            | 0x9E   | Add halfword                                    |
| ADDB2            | 0x9F   | Add byte                                        |

| Table A-10. | Instruction | Set Summary by Opcode (Continued) |
|-------------|-------------|-----------------------------------|
| Mnemonic    | Opcode      | Instruction                       |
| PUSHW       | 0xA0        | Push word                         |
| MODW2       | 0xA4        | Modulo word                       |
| MODH2       | 0xA6        | Modulo halfword                   |
| MODB2       | 0xA7        | Modulo byte                       |
| MULW2       | 0xA8        | Multiply word                     |
| MULH2       | 0xAA        | Multiply halfword                 |
| MULB2       | 0xAB        | Multiply byte                     |
| DIVW2       | 0xAC        | Divide word                       |
| DIVH2       | 0xAE        | Divide halfword                   |
| DIVB2       | 0xAF        | Divide byte                       |
| ORW2        | 0xB0        | OR word                           |
| ORH2        | 0xB2        | OR halfword                       |
| ORB2        | 0xB3        | OR byte                           |
| XORW2       | 0xB4        | Exclusive OR word                 |
| XORH2       | 0xB6        | Exclusive OR halfword             |
| XORB2       | 0xB7        | Exclusive OR byte                 |
| ANDW2       | 0xB8        | AND word                          |
| ANDH2       | 0xBA        | AND halfword                      |
| ANDB2       | 0xBB        | AND byte                          |
| SUBW2       | 0xBC        | Subtract word                     |
| SUBH2       | <b>OxBE</b> | Subtract halfword                 |
| SUBB2       | <b>OxBF</b> | Subtract byte                     |
| ALSW3       | 0xC0        | Arithmetic left shift word        |
| ARSW3       | 0xC4        | Arithmetic right shift word       |
| ARSH3       | 0xC6        | Arithmetic right shift halfword   |
| ARSB3       | 0xC7        | Arithmetic right shift byte       |
| INSFW       | 0xC8        | Insert field word                 |
| INSFH       | 0xCA        | Insert field halfword             |
| INSFB       | 0xCB        | Insert field byte                 |
| EXTFW       | 0xCC        | Extract field word                |
| EXTFH       | 0xCE        | Extract field halfword            |
| EXTFB       | 0xCF        | Extract field byte                |
| LLSW3       | 0xD0        | Logical left shift word           |
| LLSH3       | 0xD2        | Logical left shift halfword       |
| LLSB3       | 0xD3        | Logical left shift byte           |
| LRSW3       | 0xD4        | Logical right shift word          |
| ROTW        | 0xD8        | Rotate word                       |
| ADDW3       | 0xDC        | Add word, 3-address               |
| ADDH3       | 0xDE        | Add halfword, 3-address           |
| ADDB3       | 0xDF        | Add byte, 3-address               |

## WE 32100 MICROPROCESSOR INSTRUCTION SET Instruction Set Summary by Opcode

| Table A-10. Instruction Set Summary by Opcode (Continued) |             |                                                 |
|-----------------------------------------------------------|-------------|-------------------------------------------------|
| Mnemonic                                                  | Opcode      | Instruction                                     |
| PUSHAW                                                    | 0xE0        | Push address word                               |
| MODW3                                                     | 0xE4        | Modulo word, 3-address                          |
| MODH3                                                     | 0xE6        | Modulo halfword, 3-address                      |
| MODB3                                                     | 0xE7        | Modulo byte, 3-address                          |
| MULW3                                                     | 0xE8        | Multiply word, 3-address                        |
| MULH3                                                     | 0xEA        | Multiply halfword, 3-address                    |
| MULB3                                                     | <b>OxEB</b> | Multiply byte, 3-address                        |
| DIVW3                                                     | 0xEC        | Divide word, 3-address                          |
| DIVH3                                                     | <b>OxEE</b> | Divide halfword, 3-address                      |
| DIVB3                                                     | 0xEF        | Divide byte, 3-address                          |
| ORW3                                                      | 0xF0        | OR word, 3-address                              |
| ORH3                                                      | 0xF2        | OR halfword, 3-address                          |
| ORB3                                                      | 0xF3        | OR byte, 3-address                              |
| XORW3                                                     | 0xF4        | Exclusive OR word, 3-address                    |
| XORH3                                                     | 0xF6        | Exclusive OR halfword, 3-address                |
| XORB3                                                     | 0xF7        | Exclusive OR byte, 3-address                    |
| ANDW3                                                     | 0xF8        | AND word, 3-address                             |
| ANDH3                                                     | 0xFA        | AND halfword, 3-address                         |
| ANDB3                                                     | 0xFB        | AND byte, 3-address                             |
| SUBW3                                                     | 0xFC        | Subtract word, 3-address                        |
| SUBH3                                                     | 0xFE        | Subtract halfword, 3-address                    |
| SUBB3                                                     | 0xFF        | Subtract byte, 3-address                        |
| RVC                                                       | 0x60        | Return on overflow clear                        |
| BVCH                                                      | 0x62        | Branch on overflow clear, halfword displacement |
| BVCB                                                      | 0x63        | Branch on overflow clear, byte displacement     |
| RNEQU                                                     | 0x64        | Return on not equal (unsigned)                  |
| BNEH                                                      | 0x66        | Branch on not equal halfword (duplicate)        |
| BNEB                                                      | 0x67        | Branch on not equal byte (duplicate)            |
| RVS                                                       | 0x68        | Return on overflow set                          |
| BVSH                                                      | 0x6A        | Branch on overflow set, halfword displacement   |
| BVSB                                                      | 0x6B        | Branch on overflow set, byte displacement       |
| REQLU                                                     | 0x6C        | Return on equal (unsigned)                      |
| BEH                                                       | 0x6E        | Branch on equal halfword (duplicate)            |
| BEB                                                       | 0x6F        | Branch on equal byte (duplicate)                |

,

)

| Table A-10. Instruction Set Summary by Opcode (Continued) |        |                                            |
|-----------------------------------------------------------|--------|--------------------------------------------|
| Mnemonic                                                  | Opcode | Instruction                                |
| NOP                                                       | 0x70   | No operation, 1 byte                       |
| NOP3                                                      | 0x72   | No operation, 3 bytes                      |
| NOP2                                                      | 0x73   | No operation, 2 bytes                      |
| RNEQ                                                      | 0x74   | Return on not equal (signed)               |
| BNEH                                                      | 0x76   | Branch on not equal halfword               |
| BNEB                                                      | 0x77   | Branch on not equal                        |
| RSB                                                       | 0x78   | Return from subroutine                     |
| BRH                                                       | 0x7A   | Branch with halfword (16-bit) displacement |
| BRH                                                       | 0x7B   | Branch with byte (8-bit) displacement      |
| REQL                                                      | 0x7C   | Return on equal (signed)                   |
| BEH                                                       | 0x7E   | Branch on equal halfword                   |
| BEB                                                       | 0x7F   | Branch on equal byte                       |
| CLRW                                                      | 0x80   | Clear word                                 |
| CLRH                                                      | 0x82   | Clear halfword                             |
| CLRB                                                      | 0x83   | Clear byte                                 |
| MOVW                                                      | 0x84   | Move word                                  |
| MOVH                                                      | 0x86   | Move halfword                              |
| MOVB                                                      | 0x87   | Move byte                                  |
| MCOMW                                                     | 0x88   | Move complemented word                     |
| MCOMH                                                     | 0x8A   | Move complemented halfword                 |
| MCOMB                                                     | 0x8B   | Move complemented byte                     |
| MNEGW                                                     | 0x8C   | Move negated word                          |
| MNEGH                                                     | 0x8E   | Move negated halfword                      |
| MNEGB                                                     | 0x8F   | Move negated byte                          |
| INCW                                                      | 0x90   | Increment word                             |
| INCH                                                      | 0x92   | Increment halfword                         |
| INCB                                                      | 0x93   | Increment byte                             |
| DECW                                                      | 0x94   | Decrement word                             |
| DECH                                                      | 0x96   | Decrement halfword                         |
| DECB                                                      | 0x97   | Decrement byte                             |
| ADDW2                                                     | 0x9C   | Add word                                   |
| ADDH2                                                     | 0x9E   | Add halfword                               |
| ADDB2                                                     | 0x9F   | Add byte                                   |
| PUSHW                                                     | 0xA0   | Push word                                  |
| MODW2                                                     | 0xA4   | Modulo word                                |
| MODH2                                                     | 0xA6   | Modulo halfword                            |
| MODB2                                                     | 0xA7   | Modulo byte                                |
| MULW2                                                     | 0xA8   | Multiply word                              |
| MULH2                                                     | 0xAA   | Multiply halfword                          |
| MULB2                                                     | 0xAB   | Multiply byte                              |
| DIVW2                                                     | 0xAC   | Divide word                                |
| DIVH2                                                     | 0xAE   | Divide halfword                            |
| DIVB2                                                     | 0xAF   | Divide byte                                |

## WE 32100 MICROPROCESSOR INSTRUCTION SET Instruction Set Summary by Opcode

.

| Table A-10. | Instruction S | Set Summary by Opcode (Continued) |
|-------------|---------------|-----------------------------------|
| Mnemonic    | Opcode        | Instruction                       |
| ORW2        | 0xB0          | OR word                           |
| ORH2        | 0xB2          | OR halfword                       |
| ORB2        | 0xB3          | OR byte                           |
| XORW2       | 0xB4          | Exclusive OR word                 |
| XORH2       | 0xB6          | Exclusive OR halfword             |
| XORB2       | • 0xB7        | Exclusive OR byte                 |
| ANDW2       | 0xB8          | AND word                          |
| ANDH2       | 0xBA          | AND halfword                      |
| ANDB2       | 0xBB          | AND byte                          |
| SUBW2       | 0xBC          | Subtract word                     |
| SUBH2       | 0xBE          | Subtract halfword                 |
| SUBB2       | 0xBF          | Subtract byte                     |
| ALSW3       | 0xC0          | Arithmetic left shift word        |
| ARSW3       | 0xC4          | Arithmetic right shift word       |
| ARSH3       | 0xC6          | Arithmetic right shift halfword   |
| ARSB3       | 0xC7          | Arithmetic right shift byte       |
| INSFW       | 0xC8          | Insert field word                 |
| INSFH       | 0xCA          | Insert field halfword             |
| INSFB       | 0xCB          | Insert field byte                 |
| EXTFW       | 0xCC          | Extract field word                |
| EXTFH       | 0xCE          | Extract field halfword            |
| EXTFB       | 0xCF          | Extract field byte                |
| LLSW3       | 0xD0          | Logical left shift word           |
| LLSH3       | 0xD2          | Logical left shift halfword       |
| LLSB3       | 0xD3          | Logical left shift byte           |
| LRSW3       | 0xD4          | Logical right shift word          |
| ROTW        | 0xD8          | Rotate word                       |
| ADDW3       | 0xDC          | Add word, 3-address               |
| ADDH3       | 0xDE          | Add halfword, 3-address           |
| ADDB3       | 0xDF          | Add byte, 3-address               |
| PUSHAW      | 0xE0          | Push address word                 |
| MODW3       | 0xE4          | Modulo word, 3-address            |
| MODH3       | 0xE6          | Modulo halfword, 3-address        |
| MODB3       | 0xE7          | Modulo byte, 3-address            |
| MULW3       | 0xE8          | Multiply word, 3-address          |
| MULH3       | 0xEA          | Multiply halfword, 3-address      |
| MULB3       | <b>OxEB</b>   | Multiply byte, 3-address          |
| DIVW3       | 0xEC          | Divide word, 3-address            |
| DIVH3       | 0xEE          | Divide halfword, 3-address        |
| DIVB3       | 0xEF          | Divide byte, 3-address            |

## WE 32100 MICROPROCESSOR INSTRUCTION SET Instruction Set Summary by Opcode

| Table A-10. | Instructio | Instruction Set Summary by Opcode (Continued) |  |  |
|-------------|------------|-----------------------------------------------|--|--|
| Mnemonic    | Opcode     | Instruction                                   |  |  |
| ORW3        | 0xF0       | OR word, 3-address                            |  |  |
| ORH3        | 0xF2       | OR halfword, 3-address                        |  |  |
| ORB3        | 0xF3       | OR byte, 3-address                            |  |  |
| XORW3       | 0xF4       | Exclusive OR word, 3-address                  |  |  |
| XORH3       | 0xF6       | Exclusive OR halfword, 3-address              |  |  |
| XORB3       | 0xF7       | Exclusive OR byte, 3-address                  |  |  |
| ANDW3       | 0xF8       | AND word, 3-address                           |  |  |
| ANDH3       | 0xFA       | AND halfword, 3-address                       |  |  |
| ANDB3       | 0xFB       | AND byte, 3-address                           |  |  |
| SUBW3       | 0xFC       | Subtract word, 3-address                      |  |  |
| SUBH3       | 0xFE       | Subtract halfword, 3-address                  |  |  |
| SUBB3       | 0xFF       | Subtract byte, 3-address                      |  |  |



# APPENDIX B. IS25 INSTRUCTION SET

## CONTENTS

| B. IS25 INSTRUCTION SET                        | B-1  |
|------------------------------------------------|------|
| B.1 ADDRESSING MODES                           | B-1  |
| B.1.1 Absolute Mode                            | B-2  |
| B.1.2 Absolute Deferred Mode                   | B-2  |
| B.1.3 Displacement Mode                        | B-2  |
| B.1.4 Displacement Deferred Mode               | B-2  |
| B.1.5 External Address Mode                    | B-3  |
| B.1.6 External Address Deferred Mode           | B-3  |
| B.1.7 Immediate Mode                           | B-3  |
| B.1.8 Register Mode                            | B-3  |
| B.2 INSTRUCTION SET LISTINGS                   | B-4  |
| B.2.1 Notation                                 | B-4  |
| B.2.2 IS25 Instruction Set Descriptions        | B-4  |
| B.2.3 IS25 Instruction Set Summary by Function | B-59 |
| B.2.4 IS25 Instruction Set Summary by Mnemonic | B-63 |

#### **B. IS25 INSTRUCTION SET**

This appendix describes the IS25 Instruction Set. The IS25 Instruction Set was designed to be machine independent so that it could be used with all of the members of the 3B line of computers. Although, this instruction set can be used when writing assembly language programs for the 3B2/3B5/3B15 Computers it is suggested that this set of instructions be used only when necessary. Otherwise, all coding should be done in WE 32100 Microprocessor instructions. The remainder of this appendix describes the addressing modes available for IS25 instructions and lists each of the IS25 instructions.

#### **B.1 ADDRESSING MODES**

An addressing mode can be defined in terms of the size implied by the instruction in which it is used. The size implied by an instruction is derived either from the mnemonic operation code of the instruction (e.g., the implied size of **movb** is *byte*) or from the discussion of the semantics of the instruction (e.g., the implied size of the addressing mode for a shift count is *byte*).

An *expr* is an expression which evaluates to a value with either absolute text, data, bss type or has the external attribute at assembly time. The notation *expr* denotes the result of evaluating *expr*.

The remainder of this section discusses each of the addressing modes, summarized in Table B-1, that are used when writing code in IS25 instructions.

| Table B-1. Addressing Modes For IS25 Instructions |            |  |
|---------------------------------------------------|------------|--|
| Mode                                              | Syntax     |  |
| Absolute                                          |            |  |
| Absolute                                          | \$expr     |  |
| Absolute deferred                                 | *\$expr    |  |
| Displacement (from a register)                    |            |  |
| Displacement                                      | expr(%rn)  |  |
| Displacement deferred                             | *expr(%rn) |  |
| External Address                                  |            |  |
| External address                                  | expr       |  |
| External address deferred                         | *expr      |  |
| Immediate                                         |            |  |
| Immediate *                                       | & expr     |  |
| Register                                          |            |  |
| Register                                          | %rn        |  |

\* This mode may not be used for a destination operand.

#### **B.1.1** Absolute Mode

Syntax: \$expr

Effective address: value of expr

Operand value: data object at effective address

The value of *expr* is used as the effective address of the operand. The assembler is forced to use an absolute address for *expr*.

#### **B.1.2** Absolute Deferred Mode

Syntax: \*\$expr

Effective address: contents of word at memory location specified by expr

Operand value: data object at effective address

The value of *expr* is used as the address of a word in memory that contains the effective address of the operand. The assembler is forced to use an absolute address for *expr*.

#### **B.1.3 Displacement Mode**

Syntax: expr(reg)

Effective address: the value of the sum of the contents of expr and the contents of reg

Operand value: data object at effective address

The contents of *expr* and the contents of *reg* are added. The result is used as the effective address of the operand.

#### **B.1.4 Displacement Deferred Mode**

Syntax: \*expr(reg)

Effective address: the contents of the word at memory location specified by the sum of contents of *expr* and the contents of *reg* 

Operand value: data object at effective address

The contents of *expr* and the contents of *reg* are added. The sum is used as the address of a word in memory that contains the effective address of the operand.

#### **B.1.5 External Address Mode**

Syntax: expr

Effective address: the contents of *expr* 

Operand value: data object at effective address

The contents of *expr* is used as the effective address of the operand. The assembler chooses an appropriate addressing mode for *expr*.

#### **B.1.6 External Address Deferred Mode**

Syntax: \*expr

Effective address: contents of word at memory location specified by expr

Operand value: data object at effective address

The contents of *expr* is used as the address of a word in memory which contains the effective address of the operand. The assembler chooses an appropriate addressing mode for *expr*.

#### **B.1.7** Immediate Mode

Syntax: & expr

Effective address: none

Operand value: contents of expr

The contents of *expr* is the operand. There is no effective address associated with this mode; therefore, an assembly error occurs if this mode is used as a destination or if the address is requested by the instruction. The range of values of *expr* depends on the size implied by the instruction: for bytes, 0 through  $(2^{**}8)-1$ , halfwords,  $-(2^{**}16)$  through  $(2^{**}16)-1$ , and words,  $-(2^{**}32)$  through  $(2^{**}32)-1$ .

#### **B.1.8 Register Mode**

Syntax: reg

Effective address: none

Operand value: contents of reg

If reg is used as a source, the contents of reg are the operand. For bytes, only the lower 8 bits of reg are relevant; for halfwords, only the lower 16 bits of reg are relevant; for words, the entire contents of reg is relevant. If reg is used as a destination, the final result of the

instruction is placed into *reg*. For bytes, the lower 8 bits are changed and the upper 24 bits are made zero; for halfwords, the lower 16 bits are changed and the upper 16 bits are made copies of the most significant bit of the lower 16 bits; for words, the entire 32 bits are changed. Since a register does not have an effective address, an assembly error occurs if an address is requested by the instruction.

#### **B.2 IS25 INSTRUCTION SET LISTINGS**

B.2.2 presents descriptions of each member of the IS25 instruction set.

The descriptions are in alphabetical order and any instruction that operates on more than one type of operand, byte, halfword, or word, are listed on the same page. (For quick reference to the instructions by function or mnemonic see **B.2.3 Instruction Set Summary By Function** and **B.2.4 Instruction Set Summary By Mnemonic.**)

#### **B.2.1** Notation

Each instruction description contains four parts: assembler syntax, operation, description, and result types.

Assembler Syntax. Presents the assembly language syntax for the instruction, including any required spacing and punctuation. The user-specified elements appear in *italics*. All operands must appear in the order shown. If an instruction has byte, halfword, and word forms, all three forms are presented.

The syntax uses the following symbols to denote operands that may be written in the address modes shown in Table B-1: dst, src, count, offset, index, incr, limit, num, and width.

**Operation**. Describes the operation performed, generally, using C language syntax and the operators and symbols shown in Table B-2.

**Description**. Describes the operation performed in prose. Also, any additional explanation is included where necessary.

Result Types. Identifies the type of result of the instruction that is executed.

#### **B.2.2 IS25 Instruction Set Descriptions**

The IS25 instruction set is described in detail on the following pages.

| Tabl                                                  | e B-2. Assembly Language Operators and Symbols               |
|-------------------------------------------------------|--------------------------------------------------------------|
| Symbol                                                | Description                                                  |
| *X                                                    | Indirection; value pointed to by x                           |
| &x                                                    | Address of x                                                 |
| ~x                                                    | Complement x                                                 |
| -x                                                    | Negate x; form two's complement of x                         |
| x+y                                                   | Add y to x                                                   |
| x-y                                                   | Subtract y from x                                            |
| x*y                                                   | Multiply x by y                                              |
| x/y                                                   | Divide y into x                                              |
| x%y                                                   | Modulo x and y (remainder of x/y)                            |
| x&y                                                   | Bitwise AND x and y                                          |
| xly                                                   | Bitwise inclusive OR x and y                                 |
| x ^y                                                  | Bitwise exclusive OR XOR x and y                             |
| x< <y< th=""><th>Shift x to the left y bits</th></y<> | Shift x to the left y bits                                   |
| x>>y                                                  | Shift x to the right y bits                                  |
| x <y< th=""><th>x less than y</th></y<>               | x less than y                                                |
| x<=y                                                  | x less than or equal to y                                    |
| x>y                                                   | x greater than y                                             |
| x>=y                                                  | x greater than or equal to y                                 |
| x==y                                                  | Equality; x equal to y                                       |
| x!=y                                                  | x not equal to y                                             |
| =                                                     | Assigns the value on the right to the location identified on |
|                                                       | the left                                                     |
| ap                                                    | Argument pointer; register 10 (r10)                          |
| BEXT(x)                                               | Function that returns x, sign extended through 32 bits       |
| count                                                 | Count operand                                                |
| dst                                                   | Destination operand                                          |
| fp                                                    | Frame pointer; register 9 (r9)                               |
| incr                                                  | Incrementer operand                                          |
| index                                                 | Index operand                                                |
| limit                                                 | Limit operand                                                |
| num                                                   | Bit number operand                                           |
| pc                                                    | Program counter; register 15 (r15)                           |
| sp                                                    | Stack pointer; register 12 (r12)                             |
| src                                                   | Source operand                                               |
| tmp                                                   | Temporary storage                                            |
| TRUNC(x)                                              | Function that returns x, truncated by 1 to 3 bytes           |
| ZEXT(x)                                               | Function that returns x, zero extended through 32 bits       |

## addb2 addh2 addw2

addb2 addh2 addw2

# Add Two Operands

| Assembler<br>Syntax | addb2 src,dst Byte<br>addh2 src,dst Halfword<br>addw2 src,dst Word                                                          |
|---------------------|-----------------------------------------------------------------------------------------------------------------------------|
| Operation           | dst = dst + src                                                                                                             |
| Description         | The contents of $src$ are added to the contents of $dst$ . The result is copied back into the location specified by $dst$ . |
| Result              | dst == 0 : Zero                                                                                                             |
| Types               | dst != 0 : Non-Zero                                                                                                         |
|                     | dst $> 0$ : Positive                                                                                                        |
|                     | dst $\leq = 0$ : Not-Positive                                                                                               |
|                     | dst $< 0$ : Negative                                                                                                        |
|                     | $dst \ge 0$ : Not-Negative                                                                                                  |

## addb3 addh3 addw3

## addb3 addh3 addw3

## Add Three Operands

| Assembler   | addb3 src1, src2, dst Byte                                                                                               |
|-------------|--------------------------------------------------------------------------------------------------------------------------|
| Syntax      | addh3 src1, src2, dst Halfword                                                                                           |
|             | addw3 src1, src2, dst Word                                                                                               |
| Operation   | dst = src1 + src2                                                                                                        |
| Description | The contents of $src2$ are added to the contents of $src1$ . The result is copied into the location specified by $dst$ . |
| Result      | dst == 0: Zero                                                                                                           |
| Types       | dst != 0 : Non-Zero                                                                                                      |
|             | dst $> 0$ : Positive                                                                                                     |
|             | dst <= 0: Not-Positive                                                                                                   |
|             | dst $< 0$ : Negative                                                                                                     |
|             | $dst \ge 0$ : Not-Negative                                                                                               |

alsw2

# Arithmetic Left Shift Two Operands

| Assembler<br>Syntax | alsw2 count,dst                                                                                                                                                                                                                                                          |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation           | dst = dst << count                                                                                                                                                                                                                                                       |
| Description         | The contents of $dst$ are shifted left the number of bits specified by<br>count. The sign bit is not involved in an arithmetic left shift. Bits<br>shifted to the left are lost <i>before</i> the sign bit. The result is stored in the<br>location specified by $dst$ . |
|                     | This shift instruction operates on word destinations. <i>Count</i> is a byte operand; only the lower five bits are used (unsigned). The sign bit does not change and zeros are supplied on the right.                                                                    |
| Result              | dst == 0 : Zero                                                                                                                                                                                                                                                          |
| Types               | dst != 0 : Non-Zero                                                                                                                                                                                                                                                      |
|                     | dst $> 0$ : Positive                                                                                                                                                                                                                                                     |
|                     | $dst \le 0$ : Not-Positive                                                                                                                                                                                                                                               |
|                     | dst $< 0$ : Negative                                                                                                                                                                                                                                                     |
|                     | $dst \ge 0$ : Not-Negative                                                                                                                                                                                                                                               |

#### alsw3

## Arithmetic Left Shift Three Operands

Assembler alsw3 count,src,dst Syntax

Operation

dst = src < < count

**Description** The contents of *src* are shifted left the number of bits specified by *count*. The sign bit is not involved in an arithmetic left shift. Bits shifted to the left are lost *before* the sign bit. The result is stored in the location specified by *dst*.

This shift instruction operates on word sources and destinations. *Count* is a byte operand; only the lower five bits are used (unsigned). The sign bit does not change and zeros are supplied on the right.

Result Types dst == 0 : Zero dst != 0 : Non-Zero dst > 0 : Positive dst <= 0 : Not-Positive dst < 0 : Negative dst >= 0 : Not-Negative

andb2 andh2 andw2

## andb2 andh2 andw2

# AND Two Operands

| Assembler<br>Syntax | andb2 src,dstByteandb2 src,dstHalfwordandw2 src,dstWord                                                                                                                                                     |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation           | dst = dst & src                                                                                                                                                                                             |
| Description         | A logical AND is performed on $dst$ and $src$ and the result is stored in the location specified by $dst$ . The bits of each operand are ANDed on a one-to-one basis (i.e., $dst$ (bit 7) & $src$ (bit 7)). |
| Result<br>Types     | dst == 0 : Zero<br>dst != 0 : Non-Zero                                                                                                                                                                      |

# **AND Three Operands**

| Assembler<br>Syntax | andb3 src1, src2, dst Byte<br>andh3 src1, src2, dst Halfword                                                                                                                                                    |
|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     | andw3 src1, src2, dst Word                                                                                                                                                                                      |
| Operation           | dst = src1 & src2                                                                                                                                                                                               |
| Description         | A logical AND is performed on $src1$ and $src2$ and the result is stored in the location specified by $dst$ . The bits of each operand are ANDed on a one-to-one basis (i.e., $src1$ (bit 7) & $src2$ (bit 7)). |
| Result<br>Types     | dst == 0 : Zero $dst != 0 : Non-Zero$                                                                                                                                                                           |

## arsw2

# Arithmetic Right Shift Two Operands

| Assembler<br>Syntax | arsw2 count,dst                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation           | dst = dst >> count                                                                                                                                                                                                                                                                                                                                                                                                        |
| Description         | The contents of <i>dst</i> are shifted right the number of bits specified by <i>count</i> . The result is stored in the location specified by <i>dst</i> . The sign bit does not shift but is duplicated <i>count</i> bits to the right to make up for bits lost at the right end.<br>This shift instruction operates on word destinations. <i>Count</i> is a byte operand; only the lower five bits are used (unsigned). |
| Result              | dst == 0 : Zero                                                                                                                                                                                                                                                                                                                                                                                                           |
| Types               | dst != 0 : Non-Zero                                                                                                                                                                                                                                                                                                                                                                                                       |
| ~ J <b>F</b> ~ ~    | dst $> 0$ : Positive                                                                                                                                                                                                                                                                                                                                                                                                      |
|                     | $dst \le 0$ : Not-Positive                                                                                                                                                                                                                                                                                                                                                                                                |
|                     | dst $< 0$ : Negative                                                                                                                                                                                                                                                                                                                                                                                                      |
|                     | $dst \ge 0$ : Not-Negative                                                                                                                                                                                                                                                                                                                                                                                                |
# Arithmetic Right Shift Three Operands

| Assembler<br>Syntax | arsw3 count,src,dst                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation           | dst = src >> count                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Description         | The contents of <i>src</i> are shifted right the number of bits specified by <i>count</i> . The result is stored in the location specified by <i>dst</i> . The sign bit does not shift but is duplicated <i>count</i> bits to the right to make up for bits lost at the right end.<br>This shift instruction operates on word sources and destinations. <i>Count</i> is a byte operand; only the lower five bits are used (unsigned). |
| Result<br>Types     | dst == 0 : Zero<br>dst != 0 : Non-Zero<br>dst > 0 : Positive<br>dst <= 0 : Not-Positive<br>dst < 0 : Negative<br>dst >= 0 : Not-Negative                                                                                                                                                                                                                                                                                              |

#### bitb bith bitw

#### bitb bith bitw

### **Bit Test**

| Assembler   | bitb src1, src2 Byte                                                                                                                                                                                                                                         |  |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Syntax      | bith src1, src2 Halfword                                                                                                                                                                                                                                     |  |
| -           | bitw src1, src2 Word                                                                                                                                                                                                                                         |  |
| Operation   | tmp = src1 & src2                                                                                                                                                                                                                                            |  |
| Description | A logical AND is performed on the contents of $src1$ and $src2$ , and the result is placed in temporary storage ( <i>tmp</i> is not accessible by the programmer). This instruction is used to determine if the result of a logical AND is zero or non-zero. |  |
| Result      | tmp == 0 : Zero                                                                                                                                                                                                                                              |  |
| Types       | tmp != 0 : Non-Zero                                                                                                                                                                                                                                          |  |

**.** .

#### call

Assembler Syntax

Operation

\*sp = address\_of\_next\_instruction \*(sp + 4) = ap ap = sp - 4\*numsp = sp + 8pc = dst

call num,dst

#### Description

The address of the next instruction is pushed onto the stack followed by the contents of the **ap**. (The contents of the **ap** are placed on the stack using the address sp+4. Note that the **sp** is *not* incremented at this point.) The **ap** register receives the value determined by subtracting (4\*num) bytes from the **sp**. This causes the **ap** register to point to the first argument of the function (remember that the function arguments were pushed onto the stack prior to calling the function). The **sp** is then incremented by 8 (two words) to point to the next available word on the stack. The 2 word increment is necessary so that the previous contents of the **ap** (placed on the stack earlier) are not overwritten. Dst is then stored in the **pc** causing a jump to the function.

Num is an immediate operand in the range 0 to 65535. It is the number of words of parameters to be passed to the called function.

Result Types undefined

call

#### cmpb cmph cmpw

#### cmpb cmph cmpw

#### Compare

| Assembler | cmpb src1,src2  | Byte     |
|-----------|-----------------|----------|
| Syntax    | cmph src1, src2 | Halfword |
|           | cmpw src1, src2 | Word     |

Operation

compare src1 and src2

Description

The contents of src1 and src2 are compared and appropriate condition indicators are set. This instruction is used prior to a branch or jump instruction.

Since bytes are usually interpreted as unsigned quantities, the unsigned conditional jumps should be used after **cmpb**. If signed jumps are used, a byte value of 255 (which has a one in the upper bit position) is sensed as less than a byte value of 127 (which has a zero in the upper bit position).

Result Types

| src1 == src2 : Equal                                |
|-----------------------------------------------------|
| src1 != src2 : Not-Equal                            |
| src1 < src2: Less                                   |
| (signed comparison)                                 |
| src1 <= src2 : Less-or-Equal                        |
| (signed comparison)                                 |
| src1 > src2 : Greater                               |
| (singed comparison)                                 |
| src1 > = src2 : Greater-or-Equal                    |
| (signed comparison)                                 |
| src1 < src2: Less-Unsigned                          |
| (unsigned comparison)                               |
| <pre>src1 &lt;= src2 : Less-or-Equal-Unsigned</pre> |
| (unsigned comparison)                               |
| <pre>src1 &gt; src2 : Greater-Unsigned</pre>        |
| (unsigned comparison)                               |
| src1 >= src2 : Greater-or-Equal-Unsinged            |
| (unsigned comparison)                               |

#### divb2 divh2 divw2

# **Divide Two Operands**

| Assembler   | divb2 src,dst Byte                                                                                                            |  |  |
|-------------|-------------------------------------------------------------------------------------------------------------------------------|--|--|
| Syntax      | divh2 src,dst Halfword                                                                                                        |  |  |
|             | divw2 src,dst Word                                                                                                            |  |  |
| Operation   | dst = dst / src                                                                                                               |  |  |
| Description | The contents of $dst$ are divided by the contents of $src$ . The result is copied back into the location specified by $dst$ . |  |  |
| Result      | dst == 0: Zero                                                                                                                |  |  |
| Types       | dst != 0 : Non-Zero                                                                                                           |  |  |
| - 4         | dst > 0: Positive                                                                                                             |  |  |
|             | $dst \le 0$ : Not-Positive                                                                                                    |  |  |
|             | dst $< 0$ : Negative                                                                                                          |  |  |
|             | $dst \ge 0$ : Not-Negative                                                                                                    |  |  |
|             |                                                                                                                               |  |  |

divb3 divh3 divw3

# **Divide Three Operands**

| Assembler<br>Syntax | divb3 src1,src2,dstBytedivh3 src1,src2,dstHalfworddivw3 src1,src2,dstWord                                                                |  |  |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Operation           | dst = src2 / src1                                                                                                                        |  |  |
| Description         | The contents of $src2$ are divided by the contents of $src1$ . The result is copied into the location specified by $dst$ .               |  |  |
| Result<br>Types     | dst == 0 : Zero<br>dst != 0 : Non-Zero<br>dst > 0 : Positive<br>dst <= 0 : Not-Positive<br>dst < 0 : Negative<br>dst >= 0 : Not-Negative |  |  |

#### extzv

### **Extract Field**

| Assembler<br>Syntax | extzv src,offset,width,dst                                                                                                      |  |  |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------|--|--|
| Operation           | dst = ZEXT(FIELD(offset,width,src))                                                                                             |  |  |
| Description         | The field is extracted from <i>src</i> and copied into <i>dst</i> . The upper-bits of <i>src</i> are filled with zeros.         |  |  |
|                     | Dst is a word operand. Offset and width are immediate operands. The field is extended to 32 bits by appending high order zeros. |  |  |
| Result<br>Types     | undefined                                                                                                                       |  |  |

### insv

# **Insert Field**

| Assembler<br>Syntax | insv src,offset,width,dst                                                                                                                                    |  |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Operation           | FIELD(offset,width,dst) = TRUNC(src)                                                                                                                         |  |
| Description         | Src is truncated (high order bits are lost) to the same length as width. A copy of the truncated $src$ is then inserted into $dst$ with an offset of offset. |  |
|                     | Src is a word operand. Offset and width are immediate operands. The high order bits of src are truncated in order to fit into the field.                     |  |
| Result<br>Types     | undefined                                                                                                                                                    |  |

,

jcc

# **Conditional Jumps**

| Assembler       | jz dst                                                                                                                                                                                                                                                                                                                                                   | Zero                           |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|
| Syntax          | jnz asi                                                                                                                                                                                                                                                                                                                                                  | Not Zero                       |
|                 | jpos ast                                                                                                                                                                                                                                                                                                                                                 | Positive<br>Nut Decition       |
|                 | jnpos ast                                                                                                                                                                                                                                                                                                                                                | Not Positive                   |
|                 | jneg ast                                                                                                                                                                                                                                                                                                                                                 | Negative                       |
|                 | jnneg <i>ast</i>                                                                                                                                                                                                                                                                                                                                         | Not Negative                   |
|                 | je <i>dst</i>                                                                                                                                                                                                                                                                                                                                            | Equal                          |
|                 | jne <i>dst</i>                                                                                                                                                                                                                                                                                                                                           | Not Equal                      |
|                 | jl dst                                                                                                                                                                                                                                                                                                                                                   | Less Than                      |
|                 | jle <i>dst</i>                                                                                                                                                                                                                                                                                                                                           | Less Than or Equal             |
|                 | jg dst                                                                                                                                                                                                                                                                                                                                                   | Greater Than                   |
|                 | jge dst                                                                                                                                                                                                                                                                                                                                                  | Greater Than or Equal          |
|                 | jlu <i>dst</i>                                                                                                                                                                                                                                                                                                                                           | Less Than Unsigned             |
|                 | jleu dst                                                                                                                                                                                                                                                                                                                                                 | Less Than or Equal Unsigned    |
|                 | jgu <i>dst</i>                                                                                                                                                                                                                                                                                                                                           | Greater Than Unsigned          |
|                 | jgeu dst                                                                                                                                                                                                                                                                                                                                                 | Greater Than or Equal Unsigned |
| Operation       | if(indicate                                                                                                                                                                                                                                                                                                                                              | $pr_set) pc = dst$             |
| Description     | If the condition indicator that a particular jump instruction tests is set<br>then the contents of the <b>pc</b> are replaced by contents of $dst$ . Each<br>conditional jump instruction has an optimized branch version. Branch<br>instructions are used for displacements of 128 halfwords or less. The<br>operation for the branch instructions are: |                                |
|                 | if(indicate                                                                                                                                                                                                                                                                                                                                              | $pr_set$ ) $pc = pc + offset$  |
| Result<br>Types | unchange                                                                                                                                                                                                                                                                                                                                                 | 1                              |

jcc

jmp

# jmp

# **Unconditional Jump**

| Assembler<br>Syntax | jmp dst                                                                                                          |
|---------------------|------------------------------------------------------------------------------------------------------------------|
| Operation           | pc = dst                                                                                                         |
| Description         | The contents of the <b>pc</b> are replaced with the contents of the stoperand.<br>This is an unconditional jump. |
| Result<br>Types     | unchanged                                                                                                        |

# Jump to Subroutine

| Assembler<br>Syntax | jsb dst                                                                                                                                                                                                                                     |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation           | sp = pc<br>sp = sp + 4<br>pc = dst                                                                                                                                                                                                          |
| Description         | The contents of the $pc$ are saved on the stack. The $sp$ is then<br>incremented by 4 bytes (equivalent to 1 word). Finally, $dst$ replaces the<br>contents of the $pc$ causing program control to continue at the subroutine<br>at $dst$ . |
| Result<br>Types     | unchanged                                                                                                                                                                                                                                   |

.

# Logical Left Shift Two Operands

| Assembler   | llsw2 count,dst                                                                                                                                                                                                            |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax      |                                                                                                                                                                                                                            |
| Operation   | dst = dst << count                                                                                                                                                                                                         |
| Description | The entire contents of $dst$ and $shifted$ left <i>count</i> bits. The result is stored in the location specified by $dst$ . Count bits are lost at the right and <i>count</i> zeros are filled in at the left right right |
|             | This shift instruction operates on word sources and destinations. Count is a byte operand; only the lower 5 bits are used (unsigned).                                                                                      |
| Result      | dst == 0 : Zero                                                                                                                                                                                                            |
| Types       | dst != 0 : Non-Zero                                                                                                                                                                                                        |

llsw3

| Assembler<br>Syntax | llsw3 count,src,dst                                                                                                                                                                                                     |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation           | dst = src << count                                                                                                                                                                                                      |
| Description         | The entire contents of <i>src</i> are shifted left <i>count</i> bits. The result is stored in the location specified by <i>dst</i> . Count bits are lost at the right and <i>count</i> zeros are filled in at the left. |
|                     | This shift instruction operates on word sources and destinations. Count<br>is a byte operand; only the lower 5 bits are used (unsigned).                                                                                |
| Result              | dst == 0: Zero                                                                                                                                                                                                          |
| Types               | dst != 0 : Non-Zero                                                                                                                                                                                                     |

lrsw2

#### lrsw2

#### Logical Right Shift Two Operands

Assembler<br/>SyntaxIrsw3 count, dstOperationdst = dst >> countDescriptionThe entire contents of dst are shifted right count bits. The result is<br/>stored in the location specified by dst. Count bits are lost at the left<br/>and count zeros are filled in at the right.<br/>LeftThis shift instruction operates on word destinations. Count is a byte<br/>operand; only the lower 5 bits are used (unsigned).Result<br/>Typesdst == 0 : Zero<br/>dst != 0 : Non-Zero

lrsw3

lrsw3

|                     | A A                                                                                                                                                                                                                                                                                                                                                                          |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Assembler<br>Syntax | lrsw3 count,src,dst                                                                                                                                                                                                                                                                                                                                                          |
| Operation           | dst = src >> count                                                                                                                                                                                                                                                                                                                                                           |
| Description         | The entire contents of <i>src</i> are shifted right <i>count</i> bits. The result is<br>stored in the location specified by <i>dst</i> . <i>Count</i> bits are lost at the left<br>and <i>count</i> zeros are filled in at the right.<br>This shift instruction operates on word destinations. <i>Count</i> is a byte<br>operand; only the lower 5 bits are used (unsigned). |
| Result<br>Types     | dst == 0 : Zero<br>dst != 0 : Non-Zero                                                                                                                                                                                                                                                                                                                                       |

### Logical Right Shift Three Operands

mcomb mcomh mcomw

#### mcomb mcomh mcomw

# Move Complemented

| Assembler<br>Syntax | mcomb src,dstBytemcomh src,dstHalfwordmcomw src,dstWord                                                                                                                    |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation           | dst = -src                                                                                                                                                                 |
| Description         | The contents of $src$ are complemented (i.e., 0 bits are changed to 1 bits and 1 bits are changed to 0 bits) and the result is stored in the location specified by $dst$ . |
| Result              | dst == 0 : Zero                                                                                                                                                            |
| Types               | dst != 0 : Non-Zero                                                                                                                                                        |

#### mnegh mnegw

### mnegh mnegw

# Move Negated

| Assembler<br>Syntax | mnegh src,dst Halfword<br>mnegw src,dst Word                                                                                                       |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation           | dst = -src                                                                                                                                         |
| Description         | The two's complement of the contents of $src$ is copied into the location specified by $dst$ . Taking the two's complement of a number negates it. |
| Result              | dst == 0 : Zero                                                                                                                                    |
| Types               | dst != 0: Non-Zero                                                                                                                                 |
|                     | dst $> 0$ : Positive                                                                                                                               |
|                     | dst $\leq = 0$ : Not-Positive                                                                                                                      |
|                     | dst $< 0$ : Negative                                                                                                                               |
|                     | dst >= 0: Not-Negative                                                                                                                             |
|                     |                                                                                                                                                    |

modb2 modh2 modw2

#### modb2 modh2 modw2

# Modulo Divide Two Operands

| Assembler<br>Syntax | modb2 src,dstBytemodh2 src,dstHalfwordmodw2 src,dstWord                                                                                                     |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation           | dst = dst % src                                                                                                                                             |
| Description         | The contents of $dst$ are divided by the contents of $src$ . If the signed result has a remainder, it is copied back into the location specified by $dst$ . |
|                     | Note: The percent sign (%) is the symbol for modular division.                                                                                              |
| Result              | dst == 0: Zero                                                                                                                                              |
| Types               | dst != 0 : Non-Zero                                                                                                                                         |
|                     | dst $> 0$ : Positive                                                                                                                                        |
|                     | $dst \le 0$ : Not-Positive                                                                                                                                  |
|                     | dst $< 0$ : Negative                                                                                                                                        |
|                     | $dst \ge 0$ : Not-Negative                                                                                                                                  |

# **Modulo Divide Three Operands**

| Assembler   | modb3 src1, src2, dst Byte                                                                                                                               |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax      | modh3 src1, src2, dst Halfword                                                                                                                           |
|             | modw3 src1, src2, dst Word                                                                                                                               |
| Operation   | dst = src2 % src1                                                                                                                                        |
| Description | The contents of $src2$ are divided by the contents of $src1$ . If the signed result has a remainder, it is copied into the location specified by $dst$ . |
|             | Note: The percent sign (%) is the symbol for modular division.                                                                                           |
| Result      | dst == 0 : Zero                                                                                                                                          |
| Types       | dst != 0 : Non-Zero                                                                                                                                      |
| ~ K         | dst $> 0$ : Positive                                                                                                                                     |
|             | $dst \le 0$ : Not-Positive                                                                                                                               |
|             | dst $< 0$ : Negative                                                                                                                                     |
|             | dst >= 0: Not-Negative                                                                                                                                   |
|             |                                                                                                                                                          |

#### movaw

### **Move Address**

| Assembler<br>Syntax | movaw src,dst                                                                 |
|---------------------|-------------------------------------------------------------------------------|
| Operation           | dst = & src                                                                   |
| Description         | The address of src is copied into the location specified by dst.              |
|                     | Source and destination must be word addresses if specifying memory addresses. |
| Result              | dst == 0 : Zero                                                               |
| Types               | dst != 0 : Non-Zero                                                           |

#### movb movh movw

### Move

| Assembler   | movb src,dst Byte                                                       |
|-------------|-------------------------------------------------------------------------|
| Syntax      | movb src,dst Halfword                                                   |
|             | movb src,dst Word                                                       |
| Operation   | dst = src                                                               |
| Description | The contents of $src$ are copied into the location specified by $dst$ . |
| Result      | dst == 0 : Zero                                                         |
| Types       | dst != 0 : Non-Zero                                                     |
|             | dst $> 0$ : Positive                                                    |
|             | $dst \le 0$ : Not-Positive                                              |
|             | dst $< 0$ : Negative                                                    |
|             | $dst \ge 0$ : Not-Negative                                              |

movbbh movbbw movbhw movbbh movbbw movbhw

### Move Bit Extended

| Assembler<br>Syntax | movbbh src,dstByte to Halfwordmovbbw src,dstByte to Wordmovbhw src,dstHalfword to Word                                                                                                                                                                          |
|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation           | dst = BEXT(src)                                                                                                                                                                                                                                                 |
| Description         | The sign bit of $src$ is extended into the upper bits of $dst$ by either one,<br>two or three bytes depending on the instruction type (e.g., byte to<br>halfword extends the sign bit one byte). The result is copied into the<br>location specified by $dst$ . |
| Result              | dst = = 0: Zero                                                                                                                                                                                                                                                 |
| Types               | dst != 0 : Non-Zero                                                                                                                                                                                                                                             |
|                     | dst $> 0$ : Positive                                                                                                                                                                                                                                            |
|                     | dst $\leq = 0$ : Not-Positive                                                                                                                                                                                                                                   |
|                     | dst $< 0$ : Negative                                                                                                                                                                                                                                            |
|                     | $dst \ge 0$ : Not-Negative                                                                                                                                                                                                                                      |

#### movblb movblh movblw

#### **Move Block**

| Assembler<br>Syntax | movblb Byte<br>movblh Halfword<br>movblw Word                                                                                                                                                                                                                                                                                                                     |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation           | while $(r2 > 0)$<br>*r1 = *r0<br>$r0 = r0 + implied_size$<br>$r1 = r1 + implied_size$                                                                                                                                                                                                                                                                             |
| Description         | Register <b>r0</b> is the starting address of the source data, register <b>r1</b> is the starting address of the destination, and register <b>r2</b> is the number items of <i>implied_size</i> to be moved. The <i>implied_size</i> is dependent on the instruction type. Values for <i>implied_size</i> can be 1 (for byte), 2 (for halfword), or 4 (for word). |
|                     | After execution of the instruction, r2 contains the value zero, r0 contains the address of the first byte following the source of the moved data, and r1 contains the address of the first byte following the                                                                                                                                                     |

unchanged

destination of the moved data.

This instruction will not function properly if the starting address of the source block is smaller than the starting address of the destination block and the source and destination blocks overlap.

Result Types

**B-35** 

#### movthb movtwb movtwh

### **Move Truncated**

| Assembler<br>Syntax | movthb src,dstHalfword to Bytemovtwb src,dstWord to Bytemovtwh src,dstWord to Halfword                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation           | dst = TRUNC(src)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Description         | The uppermost bits of the contents of <i>src</i> are truncated by the amount<br>indicated by the instruction type (i.e., halfword to byte - high order byte<br>is lost, word to byte - upper 3 bytes are lost, and word to halfword -<br>upper 2 bytes are lost). The result is copied into the location specified<br>by <i>dst</i> . For condition indicator settings, the result of a halfword<br>destination is interpreted as a 16 bit signed 2's complement number; the<br>result of a byte destination is interpreted as an 8 bit unsigned binary<br>number. If <i>dst</i> is a register, a move truncated halfword to byte and a<br>move truncated word to byte put the byte result into bits 7–0 of the<br>register and puts zeros into bits $31-8$ (zero extension); a move<br>truncated word to halfword puts the halfword result into bits 15–0 of<br>the register and copies bit 15 into bits $31-16$ (sign extension). |
| Result<br>Types     | dst == 0 : Zero<br>dst != 0 : Non-Zero<br>dst > 0 : Positive<br>dst <= 0 : Not-Positive<br>dst < 0 : Negative                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

dst >= 0 : Not-Negative

#### movzbh movzbw movzhw

### **Move Zero Extended**

| Assembler<br>Syntax | movzbh src,dstByte to Halfwordmovzbw src,dstByte to Word                                                                                                  |
|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     | movzhw src, dst Halfword to Word                                                                                                                          |
| Operation           | dst = ZEXT(src) upper bits made zero                                                                                                                      |
| Description         | The contents of $src$ are expanded to the same size as $dst$ . Extended bits are set to zero. The result is copied into the location specified by $dst$ . |
| Result              | dst == 0 : Zero                                                                                                                                           |
| Types               | dst != 0 : Non-Zero                                                                                                                                       |

#### mulb2 mulh2 mulw2

# **Multiply Two Operands**

| Assembler<br>Syntax | mulb2 src,dstBytemulh2 src,dstHalfwordmulw2 src,dstWord                                                                                  |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Operation           | dst = dst * src                                                                                                                          |
| Description         | The contents of $dst$ are multiplied by the contents of $src$ . The result is copied back into the location specified by $dst$ .         |
| Result<br>Types     | dst == 0 : Zero<br>dst != 0 : Non-Zero<br>dst > 0 : Positive<br>dst <= 0 : Not-Positive<br>dst < 0 : Negative<br>dst >= 0 : Not-Negative |

# **Multiply Three Operands**

| Assembler<br>Syntax | mulb3 src1,src2,dstBytemulb3 src1,src2,dstHalfwordmulw3 src1,src2,dstWord                                                     |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------|
| Operation           | dst = src1 * src2                                                                                                             |
| Description         | The contents of $src1$ are multiplied by the contents of $src2$ . The result is copied into the location specified by $dst$ . |
| Result<br>Types     | dst == 0 : Zero<br>dst != 0 : Non-Zero<br>dst > 0 : Positive                                                                  |
|                     | dst $\leq 0$ : Not-Positive<br>dst $\leq 0$ : Negative<br>dst $\geq 0$ : Not-Negative                                         |

| orb2<br>orh2<br>orw2<br>VPcrse | orb2<br>orh2<br>orw2                                                                                                                                                                                      |
|--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Or Two Operan                  | nds                                                                                                                                                                                                       |
| Assembler<br>Syntax            | orb2 src,dst Byte<br>orh2 src,dst Halfword<br>orw2 src,dst Word                                                                                                                                           |
| Operation                      | dst = dst   src                                                                                                                                                                                           |
| Description                    | A logical OR is performed on $dst$ and $src$ and the result is stored in the location specified by $dst$ . The bits of each operand are ORed on a one-to-one basis (i.e., $dst$ (bit 7)   $src$ (bit 7)). |
| Result<br>Types                | dst == 0 : Zero<br>dst != 0 : Non-Zero                                                                                                                                                                    |

| orb3<br>orh3<br>orw3 | ,<br>-                                                               |                                                                                                                                                         | orb3<br>orh3<br>orw3 |
|----------------------|----------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|
|                      |                                                                      |                                                                                                                                                         |                      |
| Or Three Operar      | ıds                                                                  |                                                                                                                                                         |                      |
| Assembler<br>Syntax  | orb3 src1,src2,dst<br>orh3 src1,src2,dst<br>orw3 src1,src2,dst       | Byte<br>Halfword<br>Word                                                                                                                                |                      |
| Operation            | dst = src1   src2                                                    |                                                                                                                                                         |                      |
| Description          | A logical OR is per<br>the location specific<br>one-to-one basis (i. | formed on <i>src1</i> and <i>src2</i> and the result is seed by $dst$ . The bits of each operand are OI e., <i>src1</i> (bit 7)   <i>src2(bit 7)</i> ). | tored in<br>Red on a |
| Result               | dst == 0 : Zero                                                      |                                                                                                                                                         |                      |
| Types                | dst != U : Non-Zer                                                   | 0                                                                                                                                                       |                      |

# pushaw

#### pushaw

### **Push Address**

| Assembler<br>Syntax | pushaw src                                                                                                                                     |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation           | tmp = src<br>*sp = tmp<br>sp = sp + 4                                                                                                          |
| Description         | The contents of $src$ are placed in $tmp$ (temporary storage). The contents of $tmp$ are then placed on the stack and the $sp$ is incremented. |
|                     | Source must be a word address if specifying a memory address.                                                                                  |
| Result<br>Types     | dst == 0 : Zero $dst != 0 : Non-Zero$                                                                                                          |

.

#### pushbb pushbh

#### pushbb pushbh

#### **Push Bit Extended**

| Assembler       | pushbb src Byte                                                                                                                                                                                                                                                                                                                           |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax          | pushbh src Halfword                                                                                                                                                                                                                                                                                                                       |
| Operation       | tmp = BEXT(src)<br>*sp = tmp<br>sp = sp + 4                                                                                                                                                                                                                                                                                               |
| Description     | The high order bit of <i>src</i> is extended into the high order two or three bytes of <i>tmp</i> (temporary storage) depending on the instruction type. The low order byte or halfword of <i>src</i> is copied into the low order byte or halfword of <i>tmp</i> . <i>Tmp</i> is pushed onto the stack and the <b>sp</b> is incremented. |
| Result<br>Types | dst == 0 : Zero<br>dst != 0 : Non-Zero<br>dst > 0 : Positive<br>dst <= 0 : Not-Positive<br>dst < 0 : Negative<br>dst >= 0 : Not-Negative                                                                                                                                                                                                  |

# pushw

### Push

| Assembler   | pushw <i>src</i>                                                                                                                                           |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax      |                                                                                                                                                            |
| Operation   | tmp = src                                                                                                                                                  |
|             | sp = tmp                                                                                                                                                   |
|             | sp = sp + 4                                                                                                                                                |
| Description | The contents of <i>src</i> are placed in $tmp$ (temporary storage). The contents of $tmp$ are then pushed onto the stack and the <b>sp</b> is incremented. |
| Result      | dst == 0: Zero                                                                                                                                             |
| Types       | dst != 0 : Non-Zero                                                                                                                                        |
|             | dst $> 0$ : Positive                                                                                                                                       |
|             | dst $\leq = 0$ : Not-Positive                                                                                                                              |
|             | dst $< 0$ : Negative                                                                                                                                       |
|             | $dst \ge 0$ : Not-Negative                                                                                                                                 |

#### pushzb pushzh

#### pushzb pushzh

### **Push Zero Extended**

| Assembler   | pushzb src Byte                                                                                                                                                                                           |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax      | pushzh src Halfword                                                                                                                                                                                       |
| Operation   | tmp = ZEXT(src)<br>*sp = tmp<br>sp = sp + 4                                                                                                                                                               |
| Description | The high order two or three bytes of the <i>src</i> are filled with zeros and then copied into <i>tmp</i> (temporary storage). <i>Tmp</i> is then pushed onto the stack and the <b>sp</b> is incremented. |
| Result      | dst == 0 : Zero                                                                                                                                                                                           |
| Types       | dst != 0 : Non-Zero                                                                                                                                                                                       |

### **Return from Function**

| Assembler<br>Syntax | ret num                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation           | tmp = ap<br>restore from save area num registers beginning with r8 and counting<br>downward; adjust sp to contain address of saved pc<br>fp = *(sp + 8)<br>ap = *(sp + 4)<br>pc = *sp<br>sp = tmp                                                                                                                                                                                                                      |
| Description         | After the contents of the <b>ap</b> are placed in <i>tmp</i> (temporary storage), all automatic variables and save area registers are popped off the stack.<br>Num is an immediate operand in the range 0 to 6. It specifies which registers are to be restored (e.g., if <i>num</i> is &3, registers <b>r8</b> , <b>r7</b> , and <b>r6</b> will be restored). The effect of this instruction are undefined if either: |
|                     | • fp is not the same as it was after the execution of the save instruction that created the function activation on top of the stack.                                                                                                                                                                                                                                                                                   |
|                     | • <i>num</i> is not the same as it was after the execution of the save instruction that created the function activation on top of the stack.                                                                                                                                                                                                                                                                           |
| Result<br>Types     | undefined                                                                                                                                                                                                                                                                                                                                                                                                              |

ret

ret

# **Return from Subroutine**

| Assembler<br>Syntax | rsb                                                                                                                                                                                                                                                                                                                                                                                       |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation           | sp = sp - 4<br>pc = *sp                                                                                                                                                                                                                                                                                                                                                                   |
| Description         | This instruction is usually the last instruction in a subroutine. Before<br>using this instruction any values placed on the stack by the subroutine<br>must have been removed. When this instruction is executed, the top<br>word on the stack is copied into the <b>pc</b> . This is the address of the<br>instruction following the <b>jsb</b> instruction which called the subroutine. |
| Result<br>Types     | unchanged                                                                                                                                                                                                                                                                                                                                                                                 |

rsb

#### save

# Save Registers

| Assembler<br>Syntax | save num                                                                                                                                                                                                                                                                                                                                                      |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation           | sp = fp<br>store in save area num registers beginning with r8 and counting<br>downward; adjust sp to contain address of first word above save area<br>fp = sp                                                                                                                                                                                                 |
| Description         | This instruction should be the first instruction in a subroutine. The main purpose of this instruction is to save the contents of some general purpose registers before the subroutine changes any of their contents. The registers that can be saved are: $r3$ through $r8$ . The save instruction can also be used to allocate up to 15 words on the stack. |
|                     | Num is an immediate operand in the range 0 to 6. It is the number of registers to save (e.g., if num is &2, registers $r8$ and $r7$ are saved).<br>Note that registers $r0$ , $r1$ , and $r2$ cannot be saved.                                                                                                                                                |
| Result<br>Types     | undefined                                                                                                                                                                                                                                                                                                                                                     |

save
## subb2 subh2 subw2

## Subtract Two Operands

| Assembler   | subb2 src, dst Byte                                                                                                                |
|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| Syntax      | subh2 src,dst Halfword                                                                                                             |
|             | subw2 src,dst Word                                                                                                                 |
| Operation   | dst = dst - src                                                                                                                    |
| Description | The contents of $src$ are subtracted from the contents of $dst$ . The result is copied back into the location specified by $dst$ . |
| Result      | dst == 0 : Zero                                                                                                                    |
| Types       | dst != 0 : Non-Zero                                                                                                                |
|             | dst $> 0$ : Positive                                                                                                               |
|             | $dst \le 0$ : Not-Positive                                                                                                         |
|             | dst $< 0$ : Negative                                                                                                               |
|             | $dst \ge 0$ : Not-Negative                                                                                                         |

subb3 subh3 subw3

## **Subtract Three Operands**

| Assembler<br>Syntax | subb3 src1,src2,dst<br>subh3 src1,src2,dst<br>subw3 src1,src2,dst                                               | Byte<br>Halfword<br>Word                                                      |
|---------------------|-----------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|
| Operation           | dst = src1 - src2                                                                                               |                                                                               |
| Description         | The contents of <i>src1</i> a result is copied into th                                                          | re subtracted from the contents of $src2$ . The location specified by $dst$ . |
| Result              | dst == 0 : Zero                                                                                                 |                                                                               |
| Types               | dst != 0 : Non-Zero<br>dst > 0 : Positive<br>dst <= 0 : Not-Positi<br>dst < 0 : Negative<br>dst >= 0 : Not-Nega | ve<br>tive                                                                    |





## Unsigned Divide Two Operands

| Assembler<br>Syntax | udivb2 src,dst Byte<br>udivh2 src,dst Halfword<br>udivw2 src,dst Word                                                                  |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| Operation           | dst = dst / src                                                                                                                        |
| Description         | The contents of $dst$ are divided by the contents of $src$ . The unsigned result is copied back into the location specified by $dst$ . |
| Result              | dst == 0 : Zero                                                                                                                        |
| Types               | dst != 0 : Non-Zero                                                                                                                    |
|                     | dst $> 0$ : Positive                                                                                                                   |
|                     | $dst \leq 0$ : Not-Positive                                                                                                            |
|                     | dst $< 0$ : Negative                                                                                                                   |
|                     | $dst \ge 0$ : Not-Negative                                                                                                             |
|                     |                                                                                                                                        |

## udivb3 udivh3 udivw3

## **Unsigned Divide Three Operands**

| Assembler<br>Syntax | udivb3 src1,src2,dst Byte<br>udivh3 src1,src2,dst Halfword<br>udivw3 src1,src2,dst Word                                             |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Operation           | dst = src2 / src1                                                                                                                   |
| Description         | The contents of $src2$ are divided by the contents of $src1$ . The unsigned result is copied into the location specified by $dst$ . |
| Result              | dst == 0: Zero                                                                                                                      |
| Types               | dst != 0 : Non-Zero                                                                                                                 |
|                     | dst $> 0$ : Positive                                                                                                                |
|                     | dst $\leq = 0$ : Not-Positive                                                                                                       |
|                     | dst $< 0$ : Negative                                                                                                                |
|                     | $dst \ge 0$ : Not-Negative                                                                                                          |

## Unsigned Modulo Divide Two Operands

| Assembler<br>Syntax | umodb2 src,dst Byte<br>umodh2 src,dst Halfword<br>umodw2 src,dst Word                                                                                         |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation           | dst = dst % src                                                                                                                                               |
| Description         | The contents of $dst$ are divided by the contents of $src$ . If the unsigned result has a remainder, it is copied back into the location specified by $dst$ . |
|                     | Note: The percent sign (%) is the symbol for modular division.                                                                                                |
| Result              | dst == 0: Zero                                                                                                                                                |
| Types               | dst $!= 0$ : Non-Zero<br>dst $> 0$ : Positive                                                                                                                 |

dst > 0 : Positive dst <= 0 : Not-Positive dst < 0 : Negative dst >= 0 : Not-Negative

### umodb3 umodh3 umodw3

## **Unsigned Modulo Divide Three Operands**

| Assembler   | umodb3 src1, src2, dst Byte                                                                                                                                |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax      | umodh3 src1, src2, dst Halfword                                                                                                                            |
|             | umodw3 src1, src2, dst Word                                                                                                                                |
| Operation   | dst = src2 % src1                                                                                                                                          |
| Description | The contents of $src2$ are divided by the contents of $src1$ . If the unsigned result has a remainder, it is copied into the location specified by $dst$ . |
|             | Note: The percent sign (%) is the symbol for modular division.                                                                                             |
| Result      | dst == 0: Zero                                                                                                                                             |
| Types       | dst != 0 : Non-Zero                                                                                                                                        |
|             | dst $> 0$ : Positive                                                                                                                                       |
|             | $dst \leq 0$ : Not-Positive                                                                                                                                |
|             | dst $< 0$ : Negative                                                                                                                                       |
|             | $dst \ge 0$ : Not-Negative                                                                                                                                 |

## Unsigned Multiply Two Operands

| Assembler<br>Syntax | umul2 src,dst Byte<br>umulh2 src,dst Halfword<br>umulw2 src,dst Word                                                                        |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Operation           | dst = dst * src                                                                                                                             |
| Description         | The unsigned contents of <i>dst</i> and <i>src</i> are multiplied and the result is copied back into the location specified by <i>dst</i> . |
| Result              | dst == 0 : Zero                                                                                                                             |
| Types               | dst != 0 : Non-Zero                                                                                                                         |
|                     | dst $> 0$ : Positive                                                                                                                        |
|                     | $dst \le 0$ : Not-Positive                                                                                                                  |
|                     | dst $< 0$ : Negative                                                                                                                        |
|                     | $dst \ge 0$ : Not-Negative                                                                                                                  |

#### umulb3 umulh3 umulw3

## umulb3 umulh3 umulw3

## Unsigned Multiply Three Operands

| Assembler<br>Syntax | umul3 src1, src2, dst Byte<br>umulh3 src1, src2, dst Halfword<br>umulw3 src1, src2, dst Word                              |
|---------------------|---------------------------------------------------------------------------------------------------------------------------|
| Operation           | dst = src1 * src2                                                                                                         |
| Description         | The unsigned contents of $src1$ and $src2$ are multiplied and the result is copied into the location specified by $dst$ . |
| Result              | dst == 0: Zero                                                                                                            |
| Types               | dst != 0 : Non-Zero                                                                                                       |
|                     | dst > 0: Positive                                                                                                         |
|                     | $dst \le 0$ : Not-Positive                                                                                                |
|                     | dst $< 0$ : Negative                                                                                                      |
|                     | $dst \ge 0$ : Not-Negative                                                                                                |

## **Exclusive OR Two Operands**

| Assembler<br>Syntax | xorb2 src,dstBytexorh2 src,dstHalfwordxorw2 src,dstWord                                                                                                                                                                      |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation           | $dst = dst \ src$                                                                                                                                                                                                            |
| Description         | A logical XOR (exclusive OR) is performed on $dst$ and $src$ and the result is stored in the location specified by $dst$ . The bits of each operand are XORed on a one-to-one basis (i.e., $dst$ (bit 7) XOR $src$ (bit 7)). |
| Result<br>Types     | dst == 0 : Zero $dst != 0 : Non-Zero$                                                                                                                                                                                        |

## xorb3 xorh3 xorw3

xorb3 xorh3 xorw3

## **Exclusive OR Three Operands**

| Assembler<br>Syntax | xorb3 src1,src2,dstBytexorh3 src1,src2,dstHalfwordxorw3 src1,src2,dstWord                                                                                                                                                        |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation           | $dst = src1^{src2}$                                                                                                                                                                                                              |
| Description         | A logical XOR (exclusive OR) is performed on $src1$ and $src2$ and the result is stored in the location specified by $dst$ . The bits of each operand are XORed on a one-to-one basis (i.e., $src1$ (bit 7) XOR $src2$ (bit 7)). |
| Result<br>Types     | dst == 0 : Zero $dst != 0 : Non-Zero$                                                                                                                                                                                            |

## **B.2.3 IS25 Instruction Set Summary by Function**

| Table B-3. Data Transfer Instructions |                                     |  |
|---------------------------------------|-------------------------------------|--|
| Mnemonic                              | Name                                |  |
| Move:                                 |                                     |  |
| mcomb                                 | Move complemented byte              |  |
| mcomh                                 | Move complemented halfword          |  |
| mcomw                                 | Move complemented word              |  |
| mnegh                                 | Move negated halfword               |  |
| mnegw                                 | Move negated word                   |  |
| movaw                                 | Move address (word)                 |  |
| movb                                  | Move byte                           |  |
| movh                                  | Move halfword                       |  |
| movw                                  | Move word                           |  |
| movbbh                                | Move bit extended byte to halfword  |  |
| movbbw                                | Move bit extended byte to word      |  |
| movbhw                                | Move bit extended halfword to word  |  |
| movthb                                | Move truncated halfword to byte     |  |
| movtwb                                | Move truncated word to byte         |  |
| movtwh                                | Move truncated word to halfword     |  |
| movzbh                                | Move zero extended byte to halfword |  |
| movzbw                                | Move zero extended byte to word     |  |
| movzhw                                | Move zero extended halfword to word |  |
| Block                                 |                                     |  |
| <b>Operations</b> :                   |                                     |  |
| movbl <b>b</b>                        | Move block byte                     |  |
| movblh                                | Move block halfword                 |  |
| movblw                                | Move block word                     |  |
| Field                                 |                                     |  |
| <b>Operations:</b>                    |                                     |  |
| extzv                                 | Extract field                       |  |
| insv                                  | Insert field                        |  |

### **IS25 INSTRUCTION SET IS25 Instruction Set Summary by Function**

| Table B-4. Arithmetic Instructions |                                             |  |
|------------------------------------|---------------------------------------------|--|
| Mnemonic                           | Name                                        |  |
| Add:                               |                                             |  |
| addb2                              | Add byte, two operands                      |  |
| addh2                              | Add halfword, two operands                  |  |
| addw2                              | Add word, two operands                      |  |
| addb3                              | Add byte, three operands                    |  |
| addh3                              | Add halfword, three operands                |  |
| addw3                              | Add word, three operands                    |  |
| Subtract:                          |                                             |  |
| subb2                              | Subtract byte, two operands                 |  |
| subh2                              | Subtract halfword, two operands             |  |
| subw2                              | Subtract word, two operands                 |  |
| subb3                              | Subtract byte, three operands               |  |
| subh3                              | Subtract halfword, three operands           |  |
| subw3                              | Subtract word, three operands               |  |
| Multiply:                          |                                             |  |
| mulw2                              | Multiply word, two operands                 |  |
| mulw3                              | Multiply word, three operands               |  |
| umulw2                             | Unsigned multiply word, two operands        |  |
| umulw3                             | Unsigned multiply word, three operands      |  |
| Divide:                            |                                             |  |
| divw2                              | Divide word, two operands                   |  |
| divw3                              | Divide word, three operands                 |  |
| udivw2                             | Unsigned Divide word, two operands          |  |
| udivw3                             | Unsigned Divide word, three operands        |  |
| Modulo:                            |                                             |  |
| modw2                              | Modulo word, two operands                   |  |
| modw3                              | Modulo word, three operands                 |  |
| umodw2                             | Unsigned modulo word, two operands          |  |
| umodw3                             | Unsigned modulo word, three operands        |  |
| Arithmetic                         |                                             |  |
| Shifts:                            |                                             |  |
| alsw2                              | Arithmetic left shift word, two operands    |  |
| alw3 alsw3                         | Arithmetic left shift word, three operands  |  |
| arsw2                              | Arithmetic right shift word, two operands   |  |
| arsw3                              | Arithmetic right shift word, three operands |  |

| Table B-5. Logical Instructions |                                          |  |
|---------------------------------|------------------------------------------|--|
| Mnemonic                        | Name                                     |  |
| AND:                            |                                          |  |
| andb2                           | AND byte, two operands                   |  |
| andh2                           | AND halfword, two operands               |  |
| andw2                           | AND word, two operands                   |  |
| andb3                           | AND byte, three operands                 |  |
| andh3                           | AND halfword, three operands             |  |
| andw3                           | AND word, three operands                 |  |
| OR:                             |                                          |  |
| orb2                            | OR byte, two operands                    |  |
| orh2                            | OR halfword, two operands                |  |
| orw2                            | OR word, two operands                    |  |
| orb3                            | OR byte, three operands                  |  |
| orh3                            | OR halfword, three operands              |  |
| orw3                            | OR word, three operands                  |  |
| Exclusive                       |                                          |  |
| OR:                             |                                          |  |
| xorb2                           | Exclusive OR byte, two operands          |  |
| xorh2                           | Exclusive OR halfword, two operands      |  |
| xorw2                           | Exclusive OR word, two operands          |  |
| xorb2                           | Exclusive OR byte, three operands        |  |
| xorh2                           | Exclusive OR halfword, three operands    |  |
| xorw2                           | Exclusive OR word, three operands        |  |
| Compare                         |                                          |  |
| or Test:                        |                                          |  |
| cmpb                            | Compare byte                             |  |
| cmph                            | Compare halfword                         |  |
| cmpw                            | Compare word                             |  |
| bitb                            | Bit test byte                            |  |
| bith                            | Bit test halfword                        |  |
| bitw                            | Bit test word                            |  |
| Logical                         |                                          |  |
| Shifts:                         |                                          |  |
| llsw2                           | Logical left shift word, two operands    |  |
| llsw3                           | Logical left shift word, three operands  |  |
| lrsw2                           | Logical right shift word, two operands   |  |
| lrsw3                           | Logical right shift word, three operands |  |

## IS25 INSTRUCTION SET IS25 Instruction Set Summary by Function

| Table B-6. Program Control Instructions |                                |  |
|-----------------------------------------|--------------------------------|--|
| Mnemonic                                | Name                           |  |
| Unconditional                           |                                |  |
| Transfer:                               |                                |  |
| jmp                                     | Jump                           |  |
| Conditional                             |                                |  |
| Transfers:                              |                                |  |
| je                                      | Jump equal                     |  |
| jne                                     | Jump not equal                 |  |
| jg                                      | Jump greater                   |  |
| jge                                     | Jump greater or equal          |  |
| jgu                                     | Jump greater unsigned          |  |
| jgeu                                    | Jump greater or equal unsigned |  |
| il                                      | Jump less                      |  |
| jlu                                     | Jump less unsigned             |  |
| jle                                     | Jump less or equal             |  |
| jleu                                    | Jump less or equal unsigned    |  |
| jneg                                    | Jump negative                  |  |
| jnneg                                   | Jump not negative              |  |
| jpos                                    | Jump positive                  |  |
| jnpos                                   | Jump not positive              |  |
| jz                                      | Jump zero                      |  |
| jnz                                     | Jump not zero                  |  |
| Subroutine                              |                                |  |
| Transfer:                               |                                |  |
| jsb                                     | Jump to subroutine             |  |
| rsb                                     | Return from subroutine         |  |
| Procedure                               |                                |  |
| Transfer:                               |                                |  |
| call                                    | Call procedure                 |  |
| ret                                     | Return from procedure          |  |
| save                                    | Save registers                 |  |

| Table B-7. Stack Instructions |                             |  |
|-------------------------------|-----------------------------|--|
| Mnemonic                      | Name                        |  |
| pushaw                        | Push address (word)         |  |
| pushbb                        | Push extended byte          |  |
| pushbh                        | Push extended halfword      |  |
| pushw                         | Push word                   |  |
| pushzb                        | Push zero extended byte     |  |
| pushzh                        | Push zero extended halfword |  |

## **B.2.4 IS25 Instruction Set Summary by Mnemonic**

| Table B-8. | IS25 Instruction Set Summary by Mnemonic    |
|------------|---------------------------------------------|
| Mnemonic   | Name                                        |
| addb2      | Add byte, two operands                      |
| addb3      | Add byte, three operands                    |
| addh2      | Add halfword, two operands                  |
| addh3      | Add halfword, three operands                |
| addw2      | Add word, two operands                      |
| addw3      | Add word, three operands                    |
| alsw2      | Arithmetic left shift word, two operands    |
| alw3 Alsw3 | Arithmetic left shift word, three operands  |
| andb2      | AND byte, two operands                      |
| andb3      | AND byte, three operands                    |
| andh2      | AND halfword, two operands                  |
| andh3      | AND halfword, three operands                |
| andw2      | AND word, two operands                      |
| andw3      | AND word, three operands                    |
| arsw2      | Arithmetic right shift word, two operands   |
| arsw3      | Arithmetic right shift word, three operands |
| bitb       | Bit test byte                               |
| bith       | Bit test halfword                           |
| bitw       | Bit test word                               |
| call       | Call procedure                              |
| cmpb       | Compare byte                                |
| cmph       | Compare halfword                            |
| cmpw       | Compare word                                |
| divw2      | Divide word, two operands                   |
| divw3      | Divide word, three operands                 |
| extzv      | Extract field                               |
| insv       | Insert field                                |
| je         | Jump equal                                  |
| jg         | Jump greater                                |
| jge        | Jump greater or equal                       |
| jgeu       | Jump greater or equal unsigned              |

| Table B-8. IS25 Instruction Set Summary by Mnemonic (Continued) |                                          |
|-----------------------------------------------------------------|------------------------------------------|
| Mnemonic                                                        | Name                                     |
| jgu                                                             | Jump greater unsigned                    |
| jl                                                              | Jump less                                |
| jle                                                             | Jump less or equal                       |
| jleu                                                            | Jump less or equal unsigned              |
| jlu                                                             | Jump less unsigned                       |
| jmp                                                             | Jump                                     |
| jne                                                             | Jump not equal                           |
| jneg                                                            | Jump negative                            |
| jnneg                                                           | Jump not negative                        |
| jnpos                                                           | Jump not positive                        |
| jnz                                                             | Jump not zero                            |
| jpos                                                            | Jump positive                            |
| jsb                                                             | Jump to subroutine                       |
| jz                                                              | Jump zero                                |
| llsw2                                                           | Logical left shift word, two operands    |
| llsw3                                                           | Logical left shift word, three operands  |
| lrsw2                                                           | Logical right shift word, two operands   |
| lrsw3                                                           | Logical right shift word, three operands |
| mcomb                                                           | Move complemented byte                   |
| mcomh                                                           | Move complemented halfword               |
| mcomw                                                           | Move complemented word                   |
| mnegh                                                           | Move negated halfword                    |
| mnegw                                                           | Move negated word                        |
| modw2                                                           | Modulo word, two operands                |
| modw3                                                           | Modulo word, three operands              |
| movaw                                                           | Move address (word)                      |
| movb                                                            | Move byte                                |
| movbbh                                                          | Move bit extended byte to halfword       |
| movbbw                                                          | Move bit extended byte to word           |
| movbhw                                                          | Move bit extended halfword to word       |
| movblb                                                          | Move block byte                          |
| movblh                                                          | Move block halfword                      |
| movblw                                                          | Move block word                          |
| movh                                                            | Move halfword                            |
| movthb                                                          | Move truncated halfword to byte          |
| movtwb                                                          | Move truncated word to byte              |
| movtwh                                                          | Move truncated word to halfword          |
| movw                                                            | Move word                                |
| movzbh                                                          | Move zero extended byte to halfword      |
| movzbw                                                          | Move zero extended byte to word          |

#### IS25 INSTRUCTION SET IS25 Instruction Set Summary by Mnemonic

| Table B-8. | IS25 Instruction Set Summary by Mnemonic (Continued) |
|------------|------------------------------------------------------|
| Mnemonic   | Name                                                 |
| movzhw     | Move zero extended halfword to word                  |
| mulw2      | Multiply word, two operands                          |
| mulw3      | Multiply word, three operands                        |
| orb2       | OR byte, two operands                                |
| orb3       | OR byte, three operands                              |
| orh2       | OR halfword, two operands                            |
| orh3       | OR halfword, three operands                          |
| orw2       | OR word, two operands                                |
| orw3       | OR word, three operands                              |
| pushaw     | Push address (word)                                  |
| pushbb     | Push extended byte                                   |
| pushbh     | Push extended halfword                               |
| pushw      | Push word                                            |
| pushzb     | Push zero extended byte                              |
| pushzh     | Push zero extended halfword                          |
| ret        | Return from procedure                                |
| rsb        | Return from subroutine                               |
| save       | Save registers                                       |
| subb2      | Subtract byte, two operands                          |
| subb3      | Subtract byte, three operands                        |
| subh2      | Subtract halfword, two operands                      |
| subh3      | Subtract halfword, three operands                    |
| subw2      | Subtract word, two operands                          |
| subw3      | Subtract word, three operands                        |
| udivw2     | Unsigned Divide word, two operands                   |
| udivw3     | Unsigned Divide word, three operands                 |
| umodw2     | Unsigned modulo word, two operands                   |
| umodw3     | Unsigned modulo word, three operands                 |
| umulw2     | Unsigned multiply word, two operands                 |
| umulw3     | Unsigned multiply word, three operands               |
| xorb2      | Exclusive OR byte, two operands                      |
| xorb3      | Exclusive OR byte, three operands                    |
| xorh2      | Exclusive OR halfword, two operands                  |
| xorh3      | Exclusive OR halfword, three operands                |
| xorw2      | Exclusive OR word, two operands                      |
| xorw3      | Exclusive OR word, three operands                    |

# Appendix C Sample Programs

### C. SAMPLE PROGRAMS

(Not Available at Time of Publication)



Absolute deferred mode - An address mode that uses an address embedded in the operand to locate a pointer to data.

Absolute mode - An address mode that uses an address embedded in the operand to locate data.

Addressing mode – A method of forming the effective memory address of an operand(s) in an instruction. Examples of addressing modes include register, register displacement, immediate, and absolute deferred addressing.

Alignment — The assignment of instructions and data to specific addresses, i.e., word boundaries, to increase system performance.

Architecture – Breakdown of CPU structure into various units and registers.

Argument pointer (AP) – User register that points to the beginning location in the stack where a set of arguments for a function has been pushed.

Assembler directive – A special command to the assembler which is generally not translated into machine code. Directives allow the programmer to set starting addresses of instructions and data, and to initialize variables, for example. Assembler directives are also referred to as pseudo-operations.

Assembly language – A programming language consisting primarily of mnemonics and symbolic addresses. Assembly language statements are translated by an assembler program to corresponding machine language instructions.

Assert - To drive a signal to its active state.

Bit field -A sequence of 1 to 32 bits

contained in a base word. The field is specified by the address of its base word, a bit offset, and a width.

Byte- An 8-bit quantity that may appear at any address in memory.

Cache - A high-speed memory filled at a lower speed from main memory; used to reduce memory access time.

Central Processing Unit (CPU) – The portion of a computer which includes the logic to control the interpretation and execution of machine instructions, the arithmetic and logic unit, and various registers for data storage and addressing. A microcomputer's CPU is usually a single chip called a microprocessor.

**Comment** – Statements inserted in a program for documentation purposes. Comments are ignored by the assembler or compiler.

Complementary metal oxide semiconductor (CMOS) – a fabrication technology using complementary N-channel and P-channel MOS field effect transistors to provide low power dissipation and high noise immunity.

Condition Code (NZVC) – The flags in this 4-bit field reflect the resulting status of the most recent instruction execution that affects them. The four flags are negative (N), zero (Z), overflow (V), and carry (C).

**Condition flags** – Single bits denoting the result of an operation performed by the computer. Examples are negative, zero, and carry bits.

**Coprocessor** - A support processor that operates synchronously with the CPU to provide greater throughput in arithmetic or I/O functions. **Descriptor byte** - An 8-bit quantity defining an operand's addressing mode and register fields.

**Disassembler** – A utility program which produces an assembly language listing from machine code.

**Displacement mode** – An address mode that uses a register and an offset, both embedded in the operand, added together to form the address of data.

**Displacement deferred mode** - An address mode that uses a register and an offset, both embedded in the operand, added together to form the address of a pointer to data.

**Execute unit** - The elements in this unit perform all arithmetic and logic operations, perform all shift and all rotate operations, and compute the condition flags.

**Expression** - A sequence of operands separated by operators.

Fetch Unit - The elements in this unit handle the instruction stream and perform memory-based operand accesses.

Frame pointer (FP) – User register that points to the beginning location in the stack of a functions local variables.

General-purpose registers – Nine registers (r0-r8) that may be used for high-speed accumulation, for addressing, or for temporary data storage.

**Halfword** - 16-bit quantity that may appear at any address in memory that is divisible by 2.

High level language – A programming language consisting of statements which represent procedures rather than individual machine instructions. High level language statements are usually translated by a compiler program into a series of machine language instructions. Examples of high level languages are FORTRAN, BASIC, PASCAL, and C-language.

**Interrupt** - A means by which external devices may request service by the microprocessor.

Interrupt stack pointer (ISP) - User register that contains the 32-bit memory address of the top of the interrupt stack.

**Label** - A symbolic name used in a program to identify the location of an instruction or data.

Machine language – A programming language in which each instruction is specified by numerical values. Machine language programs can be loaded directly into memory and executed.

Macro – A sequence of instructions referenced by a name. A macro processor replaces the name by the sequence. Macros enhance programming languages by making them readable or by tailoring them to specific applications.

Main controller – The microprocessor's central control unit. It is responsible for acquiring and decoding instruction opcodes and directing the action of the fetch and execute instructions.

Math Acceleration Unit (MAU) - A coprocessor providing floating point arithmetic capability for the WE 32100 Microprocessor.

Mnemonic – Symbolic names or abbreviations of assembly language instructions which denote the operation performed.

**Negate** – To drive a signal to its inactive state.

**Operand** - Data on which an operation is performed by an instruction.

**Operating system** – Software controlling the overall operation of a computer. Controls memory allocation, input and output operations, and job scheduling.

**Pipelining** – Overlapping the execution of instructions to increase the microprocessor's performance.

**Pointer** – a register or memory location containing an address.

**Processor control block (PCB)** – a process data structure in external memory that saves the context of a process when the process is not running. This context consists of the initial and current contents of control registers (PSW, PC, and SP), the last contents of registers r0 through r10, boundaries for an execution stack, and memory specifications for the process.

**Process control block pointer (PCBP)** – User register that points to the starting address of the process control block for the current process.

**Processor status work (PSW)** – User register that contains status information about the microprocessor and the current process.

**Program counter (PC)** – User register that contains the 32-bit memory address of the instruction being executed or, upon completion, contains the starting address of the next instruction to be executed.

**Pseudo operation** – See Assembler directive.

**Register** - A CPU storage unit holding bits or words.

**Register deferred mode** – An address mode that uses a register name, embedded

in an operand, that contains a pointer to data to be used by the instruction.

**Register mode** - An address mode that uses a register name, embedded in an operand, that contains data to be used by the instruction.

Stack – A reserved area of memory where the CPU saves return addresses and register data. The stack is a last-in-firstout (LIFO) queue that supports efficient subroutine linkage and local variable storage.

Stack pointer (SP) – User register that contains the current 32-bit address of the top of the execution stack; i.e., the memory address of the next item to be stored on (pushed on) the stack or the last item retrieved (popped) from the stack.

Symbol -A name recognized by an assembler and used as a label, mnemonic, or operand.

Wait-state – Idle periods that may be generated during a bus transaction to allow slow peripherals to handshake with the microprocessor.

Word - A 32-bit quantity that may appear at any register divisibly by 4.

3-state – To place an input in a highimpedance state.

#### as – Assembler

ASR - Auxiliary status register

AP - Argument pointer

BSS - Bounded static storage

C - Condition flag bit carry

CAD - Computer-aided design

CMOS – Complimentary metal-oxide semiconductor

CPU - Central processing unit

dis - Disassembler

FP - Frame Pointer

FPE - Floating point emulation library

ISP - Interrupt/stack(pointer

ld – Link editor

LSB – Least significant bit

MAU - Math acceleration unit

mmmm - Mode field

MIS - MAU instruction set

MSB - Most significant bit

N - Condition flag bit negative

NMOS – N-channel metal-oxide semiconductor

PC - Program counter

PCBP - Process(control(block/pointer

PSW - Processor/status word

RA - Return address

rrrr - Register field

SP - Stack/pointer

V – Condition flag bit overflow

Z - Condition flag bit zero



#### A

Absolute addressing modes, 5-10 Absolute Deferred addressing modes, 5-10 Addressing Modes, 5-1 absolute, 5-10 absolute deferred, 5-10 deferred displacement, 5-8 displacement, 5-6 expanded operand, 5-11 immediate, 5-9 register, 5-4 register deferred, 5-5 register mode, 5-4 summary, 5-2, 5-13 Architecture cache. 2-1 execution unit, 2-2 fetch unit, 2-1 main controller, 2-1 pipelining, 2-2 WE 32100 Microprocessor, 2-1 Argument Pointer (ap) registers, 2-4 **Arithmetic Instructions** WE 32100 Microprocessor instruction set, 6-4 as assembler, 7-1 Assembler as, 7-1 directives, 7-3 microprocessing facilities, 7-12 Assembly Language bss, 3-3 comment, 3-2 constants, 3-6 data, 3-3 executable instructions, 3-2 expressions, 3-5 label, 3-2 mnemonic, 3-2 operand, 3-2 statements, 3-1 structure, 3-1

symbols, 3-3 text, 3-3 Assembly Level Support Group, 2-3

### B

Bit Field data types, 3-1 bss assembly language, 3-3 Byte data types, 3-1

### С

C Language, 2-2 cache architectures – WE 32100 Microprocessor, 2-1 Carry/Borrow flag bits, 6-3 Comment assembly language, 3-2 Constants assembly language, 3-6 Coprocessor Instructions WE 32100 Microprocessor instruction set, 6-12

#### D

Data assembly language, 3-3 Data Transfer Instructions WE 32100 Microprocessor instruction set, 6-3 Data instruction storage, 4-4 organization, 4-1 register data storage, 4-3 storage in memory, 4-3 types, 4-1 Data Types bit field, 3-1 byte, 3-1 double, 3-1 halfword, 3-1

single, 3-1 word, 3-1 Deferred Displacement addressing modes, 5-8 dis disassembler, 8-1 Disassembler dis, 8-1 listing, 8-2 options, 8-1 Double data types, 3-1 Double Extended data types, 3-1

#### E

Executable Instructions assembly language, 3-2 Execution Unit architecture – WE 32100 Microprocessor, 2-2 Expanded Operand addressing modes, 5-11 Expressions assembly language, 3-5

#### F

Fetch Unit architecture - WE 32100 Microprocessor, 2-1 Flag Bits carry/burrow, 6-3 negative, 6-2 overflow, 6-2 zero, 6-2 Floating Point Data, 4-1 **Floating Point Emulation** Library function call listing, 10-63 summary by function, 10-83 summary by mnemonic, 10-84 Floating Point support, 10-1 data types, 10-3 MIS instruction listings, 10-5 WE 32106 MAU instruction set, 10-1 Frame Pointer (fp) registers, 2-4

#### G

General-Purpose (r0-r8) registers, 2-3

### H

Halfword data types, 3-1 High-Level Language Support Group, 2-4

#### I

Immediate addressing modes, 5-9 Interrupt Stack Pointer (isp) registers, 2-5 Instruction Set, 6-1 condition flags, 6-2 functional groups, 6-3 instructions, 6-4 *WE* 32100 Microprocessor, 6-1, A-1 IS25 Instruction Set addressing modes, B-1 listings, B-4 summary by function, B-59 summary by mnemonic, B-64

### L

Logical Instructions WE 32100 Microprocessor instruction set, 6-6

#### Μ

Main Controller architecture – WE 32100 Microprocessor, 2-1 Math Acceleration Unit Instruction Set data types, 10-3 listings, 10-5 summary by function, 10-56 summary by mnemonic, 10-60 Mnemonic assembly language, 3-2

#### Ν

Negative flag bits, 6-2

#### 0

Operand assembly language, 3-2 Operating System Interface, 9-1 Operating System Support Group, 2-5 Overflow flag bits, 6-2

#### P

Pipelining architecture - WE 32100 Microprocessor, 2-2 Process Control Black Pointer (pcbp) registers, 2-5 Processor Status Word (psw) registers, 2-5 Program Control Instructions WE 32100 Microprocessor instruction set, 6-8 Program Counter (pc) registers, 2-4

#### R

Register addressing modes, 5-4 Register Deferred addressing modes, 5-5 Registers argument pointer (ap), 2-4 frame pointer (fp), 2-4 general-purpose (r0-r8), 2-3 interrupt stack pointer (isp), 2-5 process control block pointer (pcbp), 2-5 program counter (pc), 2-4 stack pointer (sp), 2-3

#### $\mathbf{S}$

Single data types, 3-1 Stack and Miscellaneous Instructions summary by function, A-93 summary by mnemonic, A-99 summary by opcode, A-104 Stack Pointer (sp) registers, 2-3 Statements assembly language, 3-1 Symbols assembly language, 3-3

#### Т

Text assembly language, 3-3

#### W

WE 32100 Microprocessor Instruction Set arithmetic group, 6-4 coprocessor group, 6-12 data transfer group, 6-5 listings, A-1 logical group, 6-6 program control group, 6-8 stack and miscellaneous group, 6-12 summary by function, A-93 summary by mnemonic, A-99 summary by opcode, A-104 WE 32100 Microprocessor, 1-1 Word data types, 3-1

### Z

Zero flag bits, 6-2 NOTES

NOTES