# MOTOROLA M68000 FAMILY

## **Programmer's Reference Manual**

(Includes CPU32 Instructions)

### **TABLE OF CONTENTS**

| Paragraph<br>Number | Title                                                          | Page<br>Numbe |
|---------------------|----------------------------------------------------------------|---------------|
|                     | Section 1                                                      |               |
|                     | Introduction                                                   |               |
| 1.1                 | Integer Unit User Programming Model                            | 1-2           |
| 1.1.1               | Data Registers (D7 – D0)                                       |               |
| 1.1.2               | Address Registers (A7 – A0)                                    |               |
| 1.1.3               | Program Counter                                                |               |
| 1.1.4               | Condition Code Register                                        |               |
| 1.2                 | Floating-Point Unit User Programming Model                     |               |
| 1.2.1               | Floating-Point Data Registers (FP7 – FP0)                      |               |
| 1.2.2               | Floating-Point Control Register (FPCR)                         |               |
| 1.2.2.1             | Exception Enable Byte                                          |               |
| 1.2.2.2             | Mode Control Byte                                              |               |
| 1.2.3               | Floating-Point Status Register (FPSR)                          | 1-5           |
| 1.2.3.1             | Floating-Point Condition Code Byte                             | 1-5           |
| 1.2.3.2             | Quotient Byte                                                  | 1-6           |
| 1.2.3.3             | Exception Status Byte                                          | 1-6           |
| 1.2.3.4             | Accrued Exception Byte                                         | 1-7           |
| 1.2.4               | Floating-Point Instruction Address Register (FPIAR)            | 1-8           |
| 1.3                 | Supervisor Programming Model                                   | 1-8           |
| 1.3.1               | Address Register 7 (A7)                                        | 1-10          |
| 1.3.2               | Status Register                                                |               |
| 1.3.3               | Vector Base Register (VBR)                                     |               |
| 1.3.4               | Alternate Function Code Registers (SFC and DFC)                |               |
| 1.3.5               | Acu Status Register (MC68EC030 only)                           |               |
| 1.3.6               | Transparent Translation/access Control Registers               |               |
| 1.3.6.1             | Transparent Translation/access Control Register Fields for the |               |
|                     | M68030                                                         |               |
| 1.3.6.2             | Transparent Translation/access Control Register Fields for the |               |
|                     | M68040                                                         | 1-13          |
| 1.4                 | Integer Data Formats                                           |               |
| 1.5                 | Floating-Point Data Formats                                    |               |
| 1.5.1               | Packed Decimal Real Format                                     |               |
| 1.5.2               | Binary Floating-Point Formats                                  |               |
| 1.6                 | Floating-Point Data Types                                      |               |
| 1.6.1               | Normalized Numbers                                             |               |
| 1.6.2               | Denormalized Numbers                                           |               |
| 1.6.3               | Zeros                                                          |               |
| 1.6.4               | Infinities                                                     |               |
| 1.6.5               | Not-A-Numbers                                                  |               |
| 1.6.6               | Data Format and Type Summary                                   |               |
| 1.7                 | Organization of Data in Registers                              |               |
| 1.7.1               | Organization of Integer Data Formats in Registers              | 1-25          |

## **TABLE OF CONTENTS (Continued)**

| Paragraph<br>Number | Title                                                                                                   | Page<br>Numbe |
|---------------------|---------------------------------------------------------------------------------------------------------|---------------|
| 1.7.2<br>1.7.3      | Organization of Integer Data Formats in Memory Organization of Fpu Data Formats in Registers and Memory |               |
|                     | Section 2                                                                                               |               |
|                     | Addressing Capabilities                                                                                 |               |
| 2.1                 | Instruction Format                                                                                      | 2-1           |
| 2.2                 | Effective Addressing Modes                                                                              |               |
| 2.2.1               | Data Register Direct Mode                                                                               | 2-5           |
| 2.2.2               | Address Register Direct Mode                                                                            | 2-5           |
| 2.2.3               | Address Register Indirect Mode                                                                          |               |
| 2.2.4               | Address Register Indirect with Postincrement Mode                                                       |               |
| 2.2.5               | Address Register Indirect with Predecrement Mode                                                        |               |
| 2.2.6               | Address Register Indirect with Displacement Mode                                                        |               |
| 2.2.7               | Address Register Indirect with Index (8-Bit Displacement) Mode .                                        |               |
| 2.2.8               | Address Register Indirect with Index (Base Displacement) Mode.                                          |               |
| 2.2.9               | Memory Indirect Postindexed Mode                                                                        |               |
| 2.2.10              | Memory Indirect Preindexed Mode                                                                         |               |
| 2.2.11              | Program Counter Indirect with Displacement Mode                                                         |               |
| 2.2.12              | Program Counter Indirect with Index (8-Bit Displacement) Mode .                                         |               |
| 2.2.13              | Program Counter Indirect with Index (Base Displacement) Mode.                                           |               |
| 2.2.14              | Program Counter Memory Indirect Postindexed Mode                                                        |               |
| 2.2.15              | Program Counter Memory Indirect Preindexed Mode                                                         |               |
| 2.2.16              | Absolute Short Addressing Mode                                                                          |               |
| 2.2.17              | Absolute Long Addressing Mode                                                                           |               |
| 2.2.18              | Immediate Data                                                                                          |               |
| 2.3                 | Effective Addressing Mode Summary                                                                       |               |
| 2.4                 | Brief Extension Word Format Compatibility                                                               |               |
| 2.5                 | Full Extension Addressing Modes                                                                         |               |
| 2.5.1               | No Memory Indirect Action Mode                                                                          |               |
| 2.5.2               | Memory Indirect Modes                                                                                   |               |
| 2.5.2.1             | Memory Indirect with Preindex.                                                                          |               |
| 2.5.2.2             | Memory Indirect with Postindex.                                                                         |               |
| 2.5.2.3<br>2.6      | Memory Indirect with Index Suppressed  Other Data Structures                                            |               |
| 2.6.1               | System Stack                                                                                            |               |
| 2.6.2               | Queues                                                                                                  |               |
| 2.0.2               |                                                                                                         | 2 20          |
|                     | Section 3                                                                                               |               |
| 2.4                 | Instruction Set Summary                                                                                 | 0.4           |
| 3.1<br>3.1.1        | Instruction Summary                                                                                     |               |
| _                   |                                                                                                         |               |
| 3.1.2               | Integer Arithmetic Instructions                                                                         | 3-6           |

## **TABLE OF CONTENTS (Continued)**

| Paragraph<br>Number                                                                                                                                                                                                     | Title                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Page<br>Number                                                                                          |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|
| 3.1.3<br>3.1.4<br>3.1.5<br>3.1.6<br>3.1.7<br>3.1.8<br>3.1.9<br>3.1.10<br>3.1.11<br>3.1.12<br>3.1.13<br>3.2<br>3.3<br>3.3.1<br>3.3.2<br>3.3.3<br>3.3.4<br>3.3.5<br>3.5<br>3.5<br>3.5.1<br>3.5.2<br>3.6<br>3.6.1<br>3.6.2 | Logical Instructions Shift and Rotate Instructions Bit Manipulation Instructions Bit Field Instructions Binary-Coded Decimal Instructions Program Control Instructions. System Control Instructions. Cache Control Instructions (MC68040) Multiprocessor Instructions Memory Management Unit (MMU) Instructions Floating-Point Arithmetic Instructions Integer Unit Condition Code Computation Instruction Examples Using the Cas and Cas2 Instructions Using the Moves Instruction Nested Subroutine Calls Bit Field Instructions Pipeline Synchronization with the Nop Instruction. Floating-Point Instruction Details Floating-Point Computational Accuracy Intermediate Result Rounding the Result Floating-Point Postprocessing Underflow, Round, Overflow Conditional Testing | 3-8 3-10 3-10 3-11 3-12 3-14 3-14 3-15 3-15 3-20 3-20 3-20 3-20 3-21 3-21 3-21 3-23 3-24 3-25 3-27 3-28 |
| 3.7                                                                                                                                                                                                                     | Instruction Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                         |
|                                                                                                                                                                                                                         | Section 4 Integer Instructions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                         |
|                                                                                                                                                                                                                         | Section 5 Floating Point Instructions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                         |
|                                                                                                                                                                                                                         | Section 6 Supervisor (Privileged) Instructions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                         |
|                                                                                                                                                                                                                         | Section 7 CPU32 Instructions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                         |
| 8.1                                                                                                                                                                                                                     | Section 8 Instruction Format Summary Instruction Format                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 8-1                                                                                                     |
|                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                         |

## **TABLE OF CONTENTS (Continued)**

| Paragraph<br>Number                                                                                                  | Title                                                                                                                                                                                                                                                                                | Page<br>Number                                                     |
|----------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|
| 8.1.1<br>8.1.2<br>8.1.3<br>8.1.4<br>8.1.5<br>8.1.6<br>8.1.7<br>8.1.7.1<br>8.1.7.2<br>8.1.8<br>8.1.9<br>8.1.10<br>8.2 | Coprocessor ID Field. Effective Address Field Register/Memory Field Source Specifier Field Destination Register Field Conditional Predicate Field Shift and Rotate Instructions Count Register Field. Register Field. Size Field. Opmode Field Address/Data Field Operation Code Map | 8-1<br>8-1<br>8-2<br>8-2<br>8-2<br>8-2<br>8-2<br>8-4<br>8-4<br>8-4 |
|                                                                                                                      | Appendix A                                                                                                                                                                                                                                                                           |                                                                    |
|                                                                                                                      | Processor Instruction Summary                                                                                                                                                                                                                                                        |                                                                    |
| A.1                                                                                                                  | MC68000, MC68008, MC68010 Processors                                                                                                                                                                                                                                                 | A-12                                                               |
| A.1.1                                                                                                                | M68000, MC68008, and MC68010 Instruction Set                                                                                                                                                                                                                                         | A-12                                                               |
| A.1.2                                                                                                                | MC68000, MC68008, and MC68010 Addressing Modes                                                                                                                                                                                                                                       | A-16                                                               |
| A.2                                                                                                                  | MC68020 Processors                                                                                                                                                                                                                                                                   |                                                                    |
| A.2.1                                                                                                                | MC68020 Instruction Set                                                                                                                                                                                                                                                              |                                                                    |
| A.2.2                                                                                                                | MC68020 Addressing Modes                                                                                                                                                                                                                                                             |                                                                    |
| A.3                                                                                                                  | MC68030 Processors                                                                                                                                                                                                                                                                   |                                                                    |
| A.3.1                                                                                                                | MC68030 Instruction Set                                                                                                                                                                                                                                                              |                                                                    |
| A.3.2                                                                                                                | MC68030 Addressing Modes                                                                                                                                                                                                                                                             |                                                                    |
| A.4                                                                                                                  | MC68040 Processors                                                                                                                                                                                                                                                                   |                                                                    |
| A.4.1<br>A.4.2                                                                                                       | MC68040 Instruction Set                                                                                                                                                                                                                                                              |                                                                    |
| A.4.2<br>A.5                                                                                                         | MC68881/MC68882 Coprocessors                                                                                                                                                                                                                                                         |                                                                    |
| A.5.1                                                                                                                | MC68881/MC68882 Instruction Set                                                                                                                                                                                                                                                      |                                                                    |
| A.5.2                                                                                                                | MC68881/MC68882 Addressing Modes                                                                                                                                                                                                                                                     |                                                                    |
| A.6                                                                                                                  | MC68851 Coprocessors                                                                                                                                                                                                                                                                 |                                                                    |
| A.6.1                                                                                                                | MC68851 Instruction Set                                                                                                                                                                                                                                                              |                                                                    |
| A.6.2                                                                                                                | MC68851 Addressing Modes                                                                                                                                                                                                                                                             |                                                                    |
|                                                                                                                      | Appendix B                                                                                                                                                                                                                                                                           |                                                                    |
|                                                                                                                      | Exception Processing Reference                                                                                                                                                                                                                                                       |                                                                    |
| B.1<br>B.2<br>B.3                                                                                                    | Exception Vector Assignments for the M68000 Family                                                                                                                                                                                                                                   | B-3                                                                |

## **TABLE OF CONTENTS (Concluded)**

| Paragraph<br>Number | Title                  | Page<br>Number |
|---------------------|------------------------|----------------|
|                     | Appendix C             |                |
|                     | S-Record Output Format |                |
| C.1                 | S-Record Content       | C-1            |
| C.2                 | S-Record Types         | C-2            |
| C.3                 | S-Record Creation      | C-3            |

### **LIST OF FIGURES**

| igure<br>Iumber | Title                                                     | Page<br>Number |
|-----------------|-----------------------------------------------------------|----------------|
| 1-1             | M68000 Family User Programming Model                      | 1-2            |
| 1-2             | M68000 Family Floating-Point Unit User Programming Model  | 1-4            |
| 1-3             | Floating-Point Control Register                           | 1-5            |
| 1-4             | FPSR Condition Code Byte                                  | 1-6            |
| 1-5             | FPSR Quotient Code Byte                                   | 1-6            |
| 1-6             | FPSR Exception Status Byte                                | 1-6            |
| 1-7             | FPSR Accrued Exception Byte                               | 1-7            |
| 1-8             | Status Register                                           |                |
| 1-9             | MC68030 Transparent Translation/MC68EC030 Access          |                |
|                 | Control Register Format                                   | 1-12           |
| 1-10            | MC68040 and MC68LC040 Transparent Translation/MC68EC040   |                |
|                 | Access Control Register Format                            | 1-13           |
| 1-11            | Packed Decimal Real Format                                | 1-16           |
| 1-12            | Binary Floating-Point Data Formats                        | 1-16           |
| 1-13            | Normalized Number Format                                  |                |
| 1-14            | Denormalized Number Format                                | 1-18           |
| 1-15            | Zero Format                                               | 1-19           |
| 1-16            | Infinity Format                                           | 1-19           |
| 1-17            | Not-A-Number Format                                       | 1-19           |
| 1-19            | Organization of Integer Data Formats in Address Registers | 1-26           |
| 1-18            | Organization of Integer Data Formats in Data Registers    |                |
| 1-20            | Memory Operand Addressing                                 |                |
| 1-21            | Memory Organization for Integer Operands                  |                |
| 1-22            | Organization of FPU Data Formats in Memory                |                |
| 2-1             | Instruction Word General Format                           | 2-1            |
| 2-2             | Instruction Word Specification Formats                    |                |
| 2-3             | M68000 Family Brief Extension Word Formats                | 2-21           |
| 2-4             | Addressing Array Items                                    | 2-23           |
| 2-5             | No Memory Indirect Action                                 | 2-24           |
| 2-6             | Memory Indirect with Preindex                             | 2-26           |
| 2-7             | Memory Indirect with Postindex                            | 2-27           |
| 2-8             | Memory Indirect with Index Suppress                       | 2-27           |
| 3-1             | Intermediate Result Format                                | 3-24           |
| 3-2             | Rounding Algorithm Flowchart                              | 3-26           |
| 3-3             | Instruction Description Format                            | 3-33           |
| B-1             | MC68000 Group 1 and 2 Exception Stack Frame               |                |
| B-2             | MC68000 Bus or Address Error Exception Stack Frame        |                |
| B-3             | Four-Word Stack Frame, Format \$0                         | B-3            |
| B-4             | Throwaway Four-Word Stack Frame, Format \$1               | B-3            |

## LIST OF FIGURES (Concluded)

| igure<br>Iumbei | Title                                                               | Page<br>Number |
|-----------------|---------------------------------------------------------------------|----------------|
| B-5             | Six-Word Stack Frame, Format \$2                                    | B-4            |
| B-6             | MC68040 Floating-Point Post-Instruction Stack Frame, Format \$3     | B-4            |
| B-7             | MC68EC040 and MC68LC040 Floating-Point Unimplemented                |                |
|                 | Stack Frame, Format \$4                                             |                |
| B-8             | MC68040 Access Error Stack Frame, Format \$7                        | B-5            |
| B-9             | MC68010 Bus and Address Error Stack Frame, Format \$8               | B-6            |
| B-10            | MC68020 Bus and MC68030 Coprocessor Mid-Instruction                 |                |
|                 | Stack Frame, Format \$9                                             | B-6            |
| B-11            | MC68020 and MC68030 Short Bus Cycle Stack Frame, Format \$A         | B-7            |
| B-12            | MC68020 and MC68030 Long Bus Cycle Stack Frame, Format \$B          | B-8            |
| B-13            | CPU32 Bus Error for Prefetches and Operands Stack Frame, Format \$C | B-8            |
| B-14            | CPU32 Bus Error on MOVEM Operand Stack Frame, Format \$C            | B-9            |
| B-15            | CPU32 Four- and Six-Word Bus Error Stack Frame, Format \$C          | B-9            |
| B-16            | MC68881/MC68882 and MC68040 Null Stack Frame                        | B-10           |
| B-17            | MC68881 Idle Stack Frame                                            |                |
| B-18            | MC68881 Busy Stack Frame                                            | B-11           |
| B-19            | MC68882 Idle Stack Frame                                            |                |
| B-20            | MC68882 Busy Stack Frame                                            | B-11           |
| B-21            | MC68040 Idle Busy Stack Frame                                       | B-12           |
| B-22            | MC68040 Unimplimented Instruction Stack Frame                       | B-12           |
| B-23            | MC68040 Busy Stack Frame                                            | B-13           |
| C-1             | Five Fields of an S-Record                                          | C-1            |
| C-2             | Transmission of an S1 Record                                        | C-4            |

### **LIST OF TABLES**

| Table<br>Number | Title                                                        | Page<br>Number |
|-----------------|--------------------------------------------------------------|----------------|
| 1-1             | Supervisor Registers Not Related To Paged Memory Management. | 1-9            |
| 1-2             | Supervisor Registers Related To Paged Memory Management      | 1-10           |
| 1-3             | Integer Data Formats                                         |                |
| 1-4             | Single-Precision Real Format Summary Data Format             | 1-21           |
| 1-5             | Double-Precision Real Format Summary                         | 1-22           |
| 1-6             | Extended-Precision Real Format Summary                       | 1-23           |
| 1-6             | Extended-Precision Real Format Summary (Continued)           | 1-24           |
| 1-7             | Packed Decimal Real Format Summary                           |                |
| 1-8             | MC68040 FPU Data Formats and Data Types                      | 1-30           |
| 2-1             | Instruction Word Format Field Definitions                    | 2-3            |
| 2-2             | IS-I/IS Memory Indirect Action Encodings                     |                |
| 2-3             | Immediate Operand Location                                   |                |
| 2-4             | Effective Addressing Modes and Categories                    | 2-20           |
| 3-1             | Notational Conventions                                       |                |
| 3-1             | Notational Conventions (Continued)                           |                |
| 3-1             | Notational Conventions (Concluded)                           |                |
| 3-2             | Data Movement Operation Format                               |                |
| 3-3             | Integer Arithmetic Operation Format                          |                |
| 3-4             | Logical Operation Format                                     |                |
| 3-5             | Shift and Rotate Operation Format                            |                |
| 3-6             | Bit Manipulation Operation Format                            |                |
| 3-7             | Bit Field Operation Format                                   |                |
| 3-8             | Binary-Coded Decimal Operation Format                        |                |
| 3-9             | Program Control Operation Format                             |                |
| 3-10            | System Control Operation Format                              |                |
| 3-11            | Cache Control Operation Format                               |                |
| 3-12            | Multiprocessor Operations                                    |                |
| 3-13            | MMU Operation Format                                         |                |
| 3-14            | Dyadic Floating-Point Operation Format                       |                |
| 3-15            | Dyadic Floating-Point Operations                             |                |
| 3-16            | Monadic Floating-Point Operation Format                      |                |
| 3-17            | Monadic Floating-Point Operations                            | 3-17           |
| 3-18            | Integer Unit Condition Code Computations                     |                |
| 3-19            | Conditional Tests                                            |                |
| 3-20            | Operation Table Example (FADD Instruction)                   |                |
| 3-21            | FPCR Encodings                                               |                |
| 3-22            | FPCC Encodings                                               |                |
| 3-23            | Floating-Point Conditional Tests                             |                |
| 5-1             | Directly Supported Floating-Point Instructions               |                |
| 5-2             | Indirectly Supported Floating-Point Instructions             | 5-3            |

## **LIST OF TABLES (Continued)**

| able<br>Iumber | Title                                                       | Page<br>Number |
|----------------|-------------------------------------------------------------|----------------|
| 7-1            | MC68020 Instructions Not Supported                          | 7-1            |
| 7-2            | M68000 Family Addressing Modes                              |                |
| 7-3            | CPU32 Instruction Set                                       |                |
| 8-1            | Conditional Predicate Field Encoding                        | 8-3            |
| 8-2            | Operation Code Map                                          | 8-4            |
| A-1            | M68000 Family Instruction Set And Processor Cross-Reference | A-1            |
| A-2            | M68000 Family Instruction Set                               |                |
| A-3            | MC68000 and MC68008 Instruction Set                         | A-12           |
| A-4            | MC68010 Instruction Set                                     | A-14           |
| A-5            | MC68000, MC68008, and MC68010 Data Addressing Modes         | A-16           |
| A-6            | MC68020 Instruction Set Summary                             | A-17           |
| A-7            | MC68020 Data Addressing Modes                               | A-20           |
| A-8            | MC68030 Instruction Set Summary                             | A-21           |
| A-9            | MC68030 Data Addressing Modes                               | A-24           |
| A-10           | MC68040 Instruction Set                                     |                |
| A-11           | MC68040 Data Addressing Modes                               |                |
| A-12           | MC68881/MC68882 Instruction Set                             |                |
| A-13           | MC68851 Instruction Set                                     | A-31           |
| B-1            | Exception Vector Assignments for the M68000 Family          | B-2            |
| C-1            | Field Composition of an S-Record                            |                |
| C-2            | ASCII Code                                                  |                |

# SECTION 5 FLOATING POINT INSTRUCTIONS

This section contains information about the floating-point instructions for the MC68881, MC68882, and MC68040. In this section, all references to the MC68040 do not include the MC68LC040 and MC68EC040. Each instruction is described in detail, and the instruction descriptions are arranged in alphabetical order by instruction mnemonic.

All floating-point instructions apply to the MC68881 and MC68882 processors. The MC68040 directly supports part of the floating-point instructions through hardware. It indirectly supports the remainder by providing special traps and/or stack frames for the unimplemented instructions and data types. The following identification is noted under the instruction title for the MC68040:

Directly Supported—(MC6888X, MC68040)

Software Supported—(MC6888X, MC68040FPSW)

For all MC68040 floating-point instructions, the coprocessor ID field must be 001.

Table 5-1 lists the floating-point instructions directly supported by the MC68040, and Table 5-2 lists the floating-point instructions indirectly supported.

**Table 5-1. Directly Supported Floating-Point Instructions** 

| Mnemonic  | Description                                          |
|-----------|------------------------------------------------------|
| FABS      | Floating-Point Absolute Value                        |
| FADD      | Floating-Point Add                                   |
| FBcc      | Floating-Point Branch Conditionally                  |
| FCMP      | Floating-Point Compare                               |
| FDBcc     | Floating-Point Test Condition, Decrement, and Branch |
| FDIV      | Floating-Point Divide                                |
| FMOVE     | Move Floating-Point Data Register                    |
| FMOVE     | Move Floating-Point System Control Register          |
| FMOVEM    | Move Multiple Floating-Point System Data Register    |
| FMOVEM    | Move Multiple Floating-Point Control Data Register   |
| FMUL      | Floating-Point Multiply                              |
| FNEG      | Floating-Point Negate                                |
| FNOP      | No Operation                                         |
| FRESTORE* | Restore Internal Floating-Point State*               |
| FSAVE*    | Save Internal Floating-Point State*                  |
| FScc      | Set According to Floating-Point Condition            |
| FSORT     | Floating-Point Square Root                           |
| FSUB      | Floating-Point Subtract                              |
| FSGLDIV   | Floating-Point Single-Precision Divide               |
| FSFLMUL   | Floating-Point Single-Precision Multiply             |
| FTRAPcc   | Trap on Floating-Point Condition                     |
| FTST      | Test Floating-Point Operand                          |

<sup>\*</sup>These are privileged instructions; refer to **Section 6 Supervisor (Privaleged) Instructions** for detailed information.

**Table 5-2. Indirectly Supported Floating-Point Instructions** 

| Mnemonic | Description                                 |
|----------|---------------------------------------------|
| FACOS    | Floating-Point Arc Cosine                   |
| FASIN    | Floating-Point Arc Sine                     |
| FATAN    | Floating-Point Arc Tangent                  |
| FATANH   | Floating-Point Hyperbolic Arc Tangent       |
| FCOS     | Floating-Point Cosine                       |
| FCOSH    | Floating-Point Hyperbolic Cosine            |
| FETOX    | Floating-Point e <sup>x</sup>               |
| FETOXM1  | Floating-Point e <sup>x</sup> – 1           |
| FGETEXP  | Floating-Point Get Exponent                 |
| FGETMAN  | Floating-Point Get Mantissa                 |
| FINT     | Floating-Point Integer Part                 |
| FINTRZ   | Floating-Point Integer Part, Round-to- Zero |
| FLOG10   | Floating-Point Log10                        |
| FLOG2    | Floating-Point Log2                         |
| FLOGN    | Floating-Point Loge                         |
| FLOGNP1  | Floating-Point Log <sub>e</sub> (x + 1)     |
| FMOD     | Floating-Point Modulo Remainder             |
| FMOVECR  | Floating-Point Move Constant ROM            |
| FREM     | Floating-Point IEEE Remainder               |
| FSCALE   | Floating-Point Scale Exponent               |
| FSIN     | Floating-Point Sine                         |
| FSINCOS  | Floating-Point Simultaneous Sine and Cosine |
| FSINH    | Floating-Point Hyperbolic Sine              |
| FTAN     | Floating-Point Tangent                      |
| FTANH    | Floating-Point Hyperbolic Tangent           |
| FTENTOX  | Floating-Point 10 <sup>x</sup>              |
| FTWOTOX  | Floating-Point 2 <sup>x</sup>               |

FABS Floating-Point Absolute Value (MC6888X, MC68040)

**FABS** 

**Operation:** Absolute Value of Source → FPn

Assembler

**Syntax:** FABS. < fmt > < ea > ,FPn

FABS.X FPm,FPn

FABS.X FPn

\*FrABS. < fmt > < ea > ,FPn \*FrABS.X FPm,FPn

\*FrABS.X Pn

where r is rounding precision, S or D

\*Supported by MC68040 only.

**Attributes:** Format = (Byte, Word, Long, Single, Quad, Extended, Packed)

**Description:** Converts the source operand to extended precision (if necessary) and stores the absolute value of that number in the destination floating-point data register.

FABS will round the result to the precision selected in the floating-point control register. FSABS and FDABS will round the result to single or double precision, respectively, regardless of the rounding precision selected in the floating-point control register.

### **Operation Table:**

|             |   | SOURCE         |   |   |                |   |   |                |   |
|-------------|---|----------------|---|---|----------------|---|---|----------------|---|
| DESTINATION | + | In Range       | - | + | Zero           | _ | + | Infinity       | _ |
| Result      |   | Absolute Value |   |   | Absolute Value |   |   | Absolute Value |   |

NOTE: If the source operand is a NAN, refer to 1.6.5 Not-A-Numbers for more information

### **FABS**

## Floating-Point Absolute Value (MC6888X, MC68040)

**FABS** 

### Floating-Point Status Register:

Condition Codes: Affected as described in **3.6.2 Conditional Testing.** 

Quotient Byte: Not affected.

Exception Byte: BSUN Cleared

SNAN Refer to 1.6.5 Not-A-Numbers

OPERR Cleared OVFL Cleared

UNFL If the source is an extended-precision

denormalized number, refer to exception processing in the appropriate user's manual;

cleared otherwise.

DZ Cleared INEX2 Cleared

INEX1 If < fmt > is packed, refer to exception

processing in the appropriate user's manual;

cleared otherwise.

Accrued Exception Byte: Affected as described in exception processing; refer to the

appropriate user's manual.

#### **Instruction Format:**

| 1 | 5 | 14  | 13 | 12 | 11                | 10     | 9   | 8       | 7      | 6 | 5                 | 4 | 3 | 2       | 1 | 0 |
|---|---|-----|----|----|-------------------|--------|-----|---------|--------|---|-------------------|---|---|---------|---|---|
|   | 4 | 4   | 4  | 1  | COF               | PROCES | SOR | 0       | 0      |   | EFFECTIVE ADDRESS |   |   |         |   |   |
|   | ' | 1   | '  | '  | ID                |        | 0   |         | "      |   | MODE              |   | F | REGISTE | R |   |
|   | 0 | R/M | 0  |    | SOURCE<br>PECIFIE |        |     | STINATI | OPMODE |   |                   | E |   |         |   |   |

**FABS** 

## Floating-Point Absolute Value (MC6888X, MC68040)

**FABS** 

#### **Instruction Fields:**

Effective Address field—Determines the addressing mode for external operands.

If R/M = 0, this field is unused and should be all zeros.

If R/M = 1, this field specifies the location of the source operand. Only data addressing modes can be used as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn                      | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| - (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |  |  |
|-------------------------|------|----------|--|--|
| (xxx).W                 | 111  | 000      |  |  |
| (xxx).L                 | 111  | 001      |  |  |
| # < data >              | 111  | 100      |  |  |
|                         |      |          |  |  |
|                         |      |          |  |  |
| (d <sub>16</sub> ,PC)   | 111  | 010      |  |  |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |  |  |
| (bd,PC,Xn)              | 111  | 011      |  |  |
| ([bd,PC,Xn],od)         | 111  | 011      |  |  |
| ([bd,PC],Xn,od)         | 111  | 011      |  |  |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

R/M field—Specifies the source operand address mode.

- 0 The operation is register to register.
- 1 The operation is < ea > to register.

### **FABS**

## Floating-Point Absolute Value (MC6888X, MC68040)

**FABS** 

Source Specifier field—Specifies the source register or data format.

If R/M = 0, specifies the source floating-point data register.

If R/M = 1, specifies the source data format:

000 — Long-Word Integer (L)

001 — Single-Precision Real (S)

010 — Extended-Precision Real (X)

011 — Packed-Decimal Real (P)\*

100 — Word Integer (W)

101 — Double-Precision Real (D)

110 — Byte Integer (B)

\*This encoding will cause an unimplemented

data type exception in the MC68040 to allow emulation in software.

Destination Register field—Specifies the destination floating- point data register.

Opmode field—Specifies the instruction and rounding precision.

| 0011000 | FABS         | register.                            |
|---------|--------------|--------------------------------------|
| 1011000 | <b>FSABS</b> | Single-precision rounding specified. |
| 1011100 | FDABS        | Double-precision rounding specified. |

FACOS Arc Cosine (MC6888X, M68040FPSP)

**FACOS** 

**Operation:** Arc Cosine of Source  $\rightarrow$  FPn

Assembler FACOS. < fmt > < ea > ,FPn Syntax: FACOS.X FPm,FPn

FACOS.X FPn

**Attributes:** Format = (Byte, Word, Long, Single, Double, Extended, Packed)

**Description:** Converts the source operand to extended precision (if necessary) and calculates the arc cosine of that number. Stores the result in the destination floating-point data register. This function is not defined for source operands outside of the range [-1...+1]; if the source is not in the correct range, a NAN is returned as the result and the OPERR bit is set in the floating- point status register. If the source is in the correct range, the result is in the range of  $[0...\pi]$ .

### **Operation Table:**

|             |            | SOURCE |       |   |            |   |  |  |  |
|-------------|------------|--------|-------|---|------------|---|--|--|--|
| DESTINATION | + In Range | - +    | Zero  | _ | + Infinity | - |  |  |  |
| Result      | Arc Cosine |        | + π/2 |   | NAN        |   |  |  |  |

#### NOTES:

1. If the source operand is a NAN, refer to 1.6.5 Not-A-Numbers for more information.

2. Sets the OPERR bit in the floating-point status register exception byte.

### Floating-Point Status Register:

Condition Codes: Affected as described in **3.6.2 Conditional Testing**.

Quotient Byte: Not affected.

Exception Byte: BSUN Cleared

SNAN Refer to **1.6.5 Not-A-Numbers**.

OPERR Set if the source is infinity, > + 1 or < -1;

cleared otherwise.

OVFL Cleared UNFL Cleared DZ Cleared

INEX2 Refer to inexact result in the appropriate

user's manual.

INEX1 If < fmt > is packed, refer to inexact result on

decimal input in the appropriate user's

manual: cleared otherwise.

Accrued Exception Byte: Affected as described in IEEE exception and trap compati-

bility in the appropriate user's manual.

### **FACOS**

## Arc Cosine (MC6888X, M68040FPSP)

### **FACOS**

#### **Instruction Format:**

| 15 | 14  | 13 | 12 | 11                | 10    | 9                       | 8 | 7   | 6 | 5                 | 4 | 3 | 2 | 1 | 0 |  |  |
|----|-----|----|----|-------------------|-------|-------------------------|---|-----|---|-------------------|---|---|---|---|---|--|--|
| 4  | 4   | 4  | 4  | COP               | ROCES | SOR                     |   | 0 0 | 0 | EFFECTIVE ADDRESS |   |   |   |   |   |  |  |
| '  | '   | '  | '  |                   | ID    |                         | " |     |   | MODE REGISTER     |   |   |   |   |   |  |  |
| 0  | R/M | 0  |    | SOURCE<br>PECIFIE |       | DESTINATION<br>REGISTER |   |     | 0 | 0                 | 1 | 1 | 1 | 0 | 0 |  |  |

#### Instruction Fields:

Coprocessor ID field—Specifies which coprocessor in the system is to execute this instruction. Motorola assemblers default to ID = 1 for the floating-point coprocessor.

Effective Address field—Determines the addressing mode for external operands.

If R/M = 0, this field is unused and should be all zeros.

If R/M = 1, this field is encoded with an M68000 family addressing mode as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn*                     | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| - (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | 111  | 100      |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |
| ([bd,PC,Xn],od)         | 111  | 011      |
| ([bd,PC],Xn,od)         | 111  | 011      |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

R/M field—Specifies the source operand address mode.

- 0 The operation is register to register.
- 1 The operation is < ea > to register.

**FACOS** 

## Arc Cosine (MC6888X, M68040FPSP)

**FACOS** 

Source Specifier field—Specifies the source register or data format.

If R/M = 0, specifies the source floating-point data register.

If R/M = 1, specifies the source data format:

000 — Long-Word Integer (L)

001 — Single-Precision Real (S)

010 — Extended-Precision Real (X)

011 — Packed-Decimal Real (P)

100 — Word Integer (W)

101 — Double-Precision Real (D)

110 — Byte Integer (B)

Destination Register field—Specifies the destination floating- point data register. If R/ M = 0 and the source and destination fields are equal, then the input operand is taken from the specified floating-point data register, and the result is then written into the same register. If the single register syntax is used, Motorola assemblers set the source and destination fields to the same value.

**FADD** 

Floating-Point Add (MC6888X, MC68040)

**FADD** 

**Operation:** Source + FPn  $\rightarrow$  FPn

Assembler FADD. < fmt > < ea > ,FPn Syntax: FADD.X FPm,FPn

\*FrADD. < fmt > < ea > ,FPn \*FrADD.X FPm,FPn

where r is rounding precision, S or D

\*Supported by MC68040 only.

**Attributes:** Format = (Byte, Word, Long, Single, Double, Extended, Packed)

**Description:** Converts the source operand to extended precision (if necessary) and adds that number to the number contained in the destination floating-point data register. Stores the result in the destination floating-point data register.

FADD will round the result to the precision selected in the floating-point control register. FSADD and FDADD will round the result to single or double-precision, respectively, regardless of the rounding precision selected in the floating-point control register.

### **Operation Table:**

|             |   | SOURCE <sup>1</sup> |                           |                           |                  |                  |  |  |  |  |  |
|-------------|---|---------------------|---------------------------|---------------------------|------------------|------------------|--|--|--|--|--|
| DESTINATION | Ī | + In Range -        | +                         | Zero –                    | +                | Infinity –       |  |  |  |  |  |
| In Range    | + | Add                 | Add                       |                           | + inf            | -inf             |  |  |  |  |  |
| Zero        | + | Add                 | + 0.0<br>0.0 <sup>2</sup> | 0.0 <sup>2</sup><br>- 0.0 | + inf            | -inf             |  |  |  |  |  |
| Infinity    | + | + inf               |                           | + inf                     | + inf            | NAN <sup>3</sup> |  |  |  |  |  |
|             | - | – inf               |                           | – inf                     | NAN <sup>‡</sup> | -inf             |  |  |  |  |  |

- 1. If either operand is a NAN, refer to **1.6.5 Not-A-Numbers** for more information.
- 2. Returns + 0.0 in rounding modes RN, RZ, and RP; returns 0.0 in RM.
- 3. Sets the OPERR bit in the floating-point status register exception byte.

**FADD** 

## Floating-Point Add (MC6888X, MC68040)

**FADD** 

### Floating-Point Status Register:

Condition Codes: Affected as described in **3.6.2 Conditional Testing.** 

Quotient Byte: Not affected.

Exception Byte: BSUN Cleared

SNAN Refer to **1.6.5 Not-A-Numbers**.

OPERR Set if the source and the destination are

opposite-signed infinities; cleared otherwise.

OVFL Refer to exception processing in the

appropriate user's manual.

UNFL Refer to exception processing in the

appropriate user's manual.

DZ Cleared

INEX2 Refer to exception processing in the

appropriate user's manual.

INEX1 If < fmt > is packed, refer to exception

processing in the appropriate user's manual;

cleared otherwise.

Accrued Exception Byte: Affected as described in exception processing in the appro-

priate user's manual.

#### Instruction Format:

| 15 | 14  | 13 | 12 | 11                | 10     | 9   | 8                 | 7   | 6      | 5                 | 4    | 3 | 2 | 1      | 0 |  |
|----|-----|----|----|-------------------|--------|-----|-------------------|-----|--------|-------------------|------|---|---|--------|---|--|
| 1  | 4   | 4  | 4  | COF               | PROCES | SOR | 0                 | 0 0 |        | EFFECTIVE ADDRESS |      |   |   |        |   |  |
| '  | 1   | '  | '  |                   | ID     |     |                   | U   |        |                   | MODE |   | R | EGISTE | R |  |
| 0  | R/M | 0  |    | SOURCE<br>PECIFIE |        |     | STINATI<br>EGISTE | -   | OPMODE |                   |      |   |   |        |   |  |

#### **Instruction Fields:**

Effective Address field—Determines the addressing mode for external operands. If R/M = 0, this field is unused and should be all zeros.

### **FADD**

## Floating-Point Add (MC6888X, MC68040)

**FADD** 

If R/M = 1, specifies the location of the source operand location. Only data addressing modes can be used as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn                      | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| – (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register   |  |  |
|-------------------------|------|------------|--|--|
| (xxx).W                 | 111  | 000        |  |  |
| (xxx).L                 | 111  | 001        |  |  |
| # < data >              | 111  | 100        |  |  |
|                         |      |            |  |  |
|                         |      |            |  |  |
| (d <sub>16</sub> ,PC)   | 111  | 010        |  |  |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011<br>011 |  |  |
| (bd,PC,Xn)              | 111  |            |  |  |
| ([bd,PC,Xn],od)         | 111  | 011        |  |  |
| ([bd,PC],Xn,od)         | 111  | 011        |  |  |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

R/M field—Specifies the source operand address mode.

- 0 The operation is register to register.
- 1 The operation is < ea > to register.

Source Specifier field—Specifies the source register or data format.

If R/M = 0, specifies the source floating-point data register.

If R/M = 1, specifies the source data format:

000 — Long-Word Integer (L)

001 — Single-Precision Real (S)

010 — Extended-Precision Real (X)

011 — Packed-Decimal Real (P)\*

100 — Word Integer (W)

101 — Double-Precision Real (D)

110 — Byte Integer (B)

Destination Register field—Specifies the destination floating- point data register.

Opmode field—Specifies the instruction and rounding precision.

| 0100010 FADD | Rounding precision specified by the floating-point control register. |
|--------------|----------------------------------------------------------------------|
| 1100010 FSAD | D Single-precision rounding specified.                               |
| 1100110 FDAD | D Double-precision rounding specified.                               |

<sup>\*</sup>This encoding will cause an unimplemented data type exception to allow emulation in software.

FASIN

Arc Sine
(MC6888X, M68040FPSP)

FASIN

**Operation:** Arc Sine of the Source  $\rightarrow$  FPn

Assembler FASIN. < fmt > < ea > ,FPn Syntax: FASIN.X FPm,FPn FASIN.X FPn

TAOIN.A TTII

**Attributes:** Format = (Byte, Word, Long, Single, Double, Extended, Packed)

**Description:** Converts the source operand to extended precision (if necessary) and calculates the arc sine of the number. Stores the result in the destination floating-point data register. This function is not defined for source operands outside of the range [-1...+1]; if the source is not in the correct range, a NAN is returned as the result and the OPERR bit is set in the floating- point status register. If the source is in the correct range, the result is in the range of [ $-\pi/2...+\pi/2$ ].

### **Operation Table:**

|             |   | SOURCE <sup>1</sup> |   |       |      |       |   |                  |   |  |
|-------------|---|---------------------|---|-------|------|-------|---|------------------|---|--|
| DESTINATION | + | In Range            | _ | +     | Zero | _     | + | Infinity         | _ |  |
| Result      |   | Arc Sine            |   | + 0.0 |      | - 0.0 |   | NAN <sup>2</sup> |   |  |

#### NOTES:

- 1. If the source operand is a NAN, refer to **1.6.5 Not-A-Numbers** for more information.
- 2. Sets the OPERR bit in the floating-point status register exception byte.

### **FASIN**

## Arc Sine (MC6888X, M68040FPSP)

### **FASIN**

### Floating-Point Status Register:

Condition Codes: Affected as described in **3.6.2 Conditional Testing.** 

Quotient Byte: Not affected.

Exception Byte: BSUN Cleared

SNAN Refer to **1.6.5 Not-A-Numbers**.

OPERR Set if the source is infinity, > + 1 or < -1;

cleared otherwise

OVFL Cleared

UNFL Can be set for an underflow condition.

DZ Cleared

INEX2 Refer to inexact result in the appropriate

user's manual.

INEX1 If < fmt > is packed, refer to inexact result on

decimal input in the appropriate user's

manual; cleared otherwise.

Accrued Exception Byte: Affected as described in IEEE exception and trap compati-

bility in the appropriate user's manual.

#### **Instruction Format:**

| 15 | 14  | 13 | 12 | 11                | 10     | 9   | 8                 | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|-----|----|----|-------------------|--------|-----|-------------------|---|---|---|------|---------|-------|--------|---|
| 1  | 1   | 1  | 1  | COF               | PROCES | SOR | _                 | 0 | _ |   | EF   | FECTIVE | ADDRE | SS     |   |
| '  | '   | '  | '  |                   | ID     |     | 0                 | 0 | 0 |   | MODE |         | F     | EGISTE | R |
| 0  | R/M | 0  |    | SOURCE<br>PECIFIE |        |     | STINATI<br>EGISTE |   | 0 | 0 | 0    | 1       | 1     | 0      | 0 |

#### **Instruction Fields:**

Coprocessor ID field—Specifies which coprocessor in the system is to execute this instruction. Motorola assemblers default to ID = 1 for the floating-point coprocessor.

### **FASIN**

## **Arc Sine** (MC6888X, M68040FPSP)

**FASIN** 

Effective Address field—Determines the addressing mode for external operands.

If R/M = 0, this field is unused and should be all zeros.

If R/M = 1, this field is encoded with an M68000 family addressing mode as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn*                     | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| – (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | 111  | 100      |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |
| ([bd,PC,Xn],od)         | 111  | 011      |
| ([bd,PC],Xn,od)         | 111  | 011      |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

R/M field—Specifies the source operand address mode.

- 0 The operation is register to register.
- 1 The operation is < ea > to register.

Source Specifier field—Specifies the source register or data format.

If R/M = 0, specifies the source floating-point data register.

If R/M = 1, specifies the source data format:

- 000 Long-Word Integer (L)
- 001 Single-Precision Real (S)
- 010 Extended-Precision Real (X)
- 011 Packed-Decimal Real (P)
- 100 Word Integer (W)
- 101 Double-Precision Real (D)
- 110 Byte Integer (B)

Destination Register field—Specifies the destination floating- point data register. If R/ M = 0 and the source and destination fields are equal, then the input operand is taken from the specified floating-point data register, and the result is then written into the same register. If the single register syntax is used, Motorola assemblers set the source and destination fields to the same value.

**FATAN** 

## Arc Tangent (MC6888X, M68040FPSP)

**FATAN** 

**Operation:** Arc Tangent of Source  $\rightarrow$  FPn

Assembler FATAN. < fmt > < ea > ,FPn Syntax: FATAN.X FPm,FPn FATAN.X FPm.FPnz

**Attributes:** Format = (Byte, Word, Long, Single, Double, Extended, Packed)

**Description:** Converts the source operand to extended precision (if necessary) and calculates the arc tangent of that number. Stores the result in the destination floating-point data register. The result is in the range of  $[-\pi/2... + \pi/2]$ .

### **Operation Table:**

|             |   | SOURCE      |   |       |      |       |       |          |          |
|-------------|---|-------------|---|-------|------|-------|-------|----------|----------|
| DESTINATION | + | In Range    | _ | +     | Zero | _     | +     | Infinity | -        |
| Result      |   | Arc Tangent |   | + 0.0 |      | - 0.0 | + π/2 |          | $-\pi/2$ |

NOTE: If the source operand is a NAN, refer to 1.6.5 Not-A-Numbers for more information.

### Floating-Point Status Register:

Condition Codes: Affected as described in **3.6.2 Conditional Testing**.

Quotient Byte: Not affected.

Exception Byte: BSUN Cleared

SNAN Refer to **1.6.5 Not-A-Numbers**.

OPERR Cleared OVFL Cleared

UNFL Refer to underflow in the appropriate user's

manual.

DZ Cleared

INEX2 Refer to inexact result in the appropriate

user's manual.

INEX1 If < fmt > is packed, refer to inexact result on

decimal input in the appropriate user's

manual; cleared otherwise.

Accrued Exception Byte: Affected as described in IEEE exception and trap compati-

bility in the appropriate user's manual.

### **FATAN**

## Arc Tangent (MC6888X, M68040FPSP)

### **FATAN**

#### **Instruction Format:**

| 15 | 14  | 13 | 12 | 11                | 10    | 9                | 8 | 7 | 6 | 5 | 4    | 3       | 2       | 1      | 0 |
|----|-----|----|----|-------------------|-------|------------------|---|---|---|---|------|---------|---------|--------|---|
| 1  | 1   | 1  | 1  | COF               | ROCES | SOR              | 0 | 0 | _ |   | EF   | FECTIVE | E ADDRE | SS     |   |
| '  | '   | '  | '  |                   | ID    |                  | 0 | " | " |   | MODE |         | R       | EGISTE | R |
| 0  | R/M | 0  |    | SOURCE<br>PECIFIE |       | DESTINA<br>REGIS |   |   | 0 | 0 | 0    | 1       | 1       | 0      | 0 |

#### **Instruction Fields:**

Coprocessor ID field—Specifies which coprocessor in the system is to execute this instruction. Motorola assemblers default to ID = 1 for the floating-point coprocessor.

Effective Address field—Determines the addressing mode for external operands.

If R/M = 0, this field is unused and should be all zeros.

If R/M = 1, this field is encoded with an M68000 family addressing mode as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn*                     | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| - (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | 111  | 100      |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |
| ([bd,PC,Xn],od)         | 111  | 011      |
| ([bd,PC],Xn,od)         | 111  | 011      |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

R/M field—Specifies the source operand address mode.

- 0 The operation is register to register.
- 1 The operation is < ea > to register.

### **FATAN**

## Arc Tangent (MC6888X, M68040FPSP)

**FATAN** 

Source Specifier field—Specifies the source register or data format.

If R/M = 0, specifies the source floating-point data register.

If R/M = 1, specifies the source data format:

000 — Long-Word Integer (L)

001 — Single-Precision Real (S)

010 — Extended-Precision Real (X)

011 — Packed-Decimal Real (P)

100 — Word Integer (W)

101 — Double-Precision Real (D)

110 — Byte Integer (B)

Destination Register field—Specifies the destination floating- point data register. If R/ M = 0 and the source and destination fields are equal, then the input operand is taken from the specified floating-point data register, and the result is then written into the same register. If the single register syntax is used, Motorola assemblers set the source and destination fields to the same value.

**FATANH** 

Hyperbolic Arc Tangent (MC6888X, M68040FPSP)

**FATANH** 

**Operation:** Hyperbolic Arc Tangent of Source  $\rightarrow$  FPn

Assembler FATANH. < fmt > < ea > ,FPn Syntax: FATANH.X FPm,FPn FATANH.X FPn

**Attributes:** Format = (Byte, Word, Long, Single, Double, Extended, Packed)

**Description:** Converts the source operand to extended precision (if necessary) and calculates the hyperbolic arc tangent of that value. Stores the result in the destination floating-point data register. This function is not defined for source operands outside of the range ( − 1... + 1); and the result is equal to − infinity or + infinity if the source is equal to + 1 or − 1, respectively. If the source is outside of the range [ − 1... + 1], a NAN is returned as the result, and the OPERR bit is set in the floating-point status register.

### **Operation Table:**

|             |                           | S     | SOURCE <sup>1</sup> |                  |   |  |  |  |
|-------------|---------------------------|-------|---------------------|------------------|---|--|--|--|
| DESTINATION | + In Range                | - +   | Zero –              | + Infinity       | - |  |  |  |
| Result      | Hyperbolic<br>Arc Tangent | + 0.0 | - 0.0               | NAN <sup>2</sup> |   |  |  |  |

#### NOTES:

- 1. If the source operand is a NAN, refer to 1.6.5 Not-A-Numbers for more information.
- 2. Sets the OPERR bit in the floating-point status register exception byte.

### Floating-Point Status Register:

Condition Codes: Affected as described in **3.6.2 Conditional Testing**.

Quotient Byte: Not affected.

### **FATANH**

## Hyperbolic Arc Tangent (MC6888X, M68040FPSP)

### **FATANH**

Exception Byte: BSUN Cleared

SNAN Refer to **1.6.5 Not-A-Numbers**.

OPERR Set if the source is > + 1 or < -1; cleared

otherwise.

OVFL Cleared

UNFL Refer to underflow in the appropriate user's

manual.

DZ Set if the source is equal to + 1 or - 1; cleared

otherwise.

INEX2 Refer to inexact result in the appropriate

user's manual.

INEX1 If < fmt > is packed, refer to inexact result on

decimal input in the appropriate user's

manual; cleared otherwise.

Accrued Exception Byte: Affected as described in IEEE exception and trap compati-

bility in the appropriate user's manual.

#### **Instruction Format:**

| 15 | 14  | 13 | 12 | 11                | 10    | 9                       | 8 | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|-----|----|----|-------------------|-------|-------------------------|---|---|---|---|------|---------|-------|--------|---|
| 1  | 1   | 1  | 1  | COF               | ROCES | SOR                     | 0 | _ | _ |   | EF   | FECTIVE | ADDRE | SS     |   |
| '  | '   | '  | '  |                   | ID    |                         | " | " | " |   | MODE |         | R     | EGISTE | R |
| 0  | R/M | 0  |    | SOURCE<br>PECIFIE |       | DESTINATION<br>REGISTER |   | 0 | 0 | 0 | 1    | 1       | 0     | 1      |   |

#### **Instruction Fields:**

Coprocessor ID field—Specifies which coprocessor in the system is to execute this instruction. Motorola assemblers default to ID = 1 for the floating-point coprocessor.

### **FATANH**

## Hyperbolic Arc Tangent (MC6888X, M68040FPSP)

### **FATANH**

Effective Address field—Determines the addressing mode for external operands.

If R/M = 0, this field is unused and should be all zeros.

If R/M = 1, this field is encoded with an M68000 family addressing mode as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn*                     | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| – (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |  |  |  |
|-------------------------|------|----------|--|--|--|
| (xxx).W                 | 111  | 000      |  |  |  |
| (xxx).L                 | 111  | 001      |  |  |  |
| # < data >              | 111  | 100      |  |  |  |
|                         |      |          |  |  |  |
|                         |      |          |  |  |  |
| (d <sub>16</sub> ,PC)   | 111  | 010      |  |  |  |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |  |  |  |
| (bd,PC,Xn)              | 111  | 011      |  |  |  |
| ([bd,PC,Xn],od)         | 111  | 011      |  |  |  |
| ([bd,PC],Xn,od)         | 111  | 011      |  |  |  |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

R/M field—Specifies the source operand address mode.

- 0 The operation is register to register.
- 1 The operation is < ea > to register.

Source Specifier field—Specifies the source register or data format.

If R/M = 0, specifies the source floating-point data register.

If R/M = 1, specifies the source data format:

- 000 Long-Word Integer (L)
- 001 Single-Precision Real (S)
- 010 Extended-Precision Real (X)
- 011 Packed-Decimal Real (P)
- 100 Word Integer (W)
- 101 Double-Precision Real (D)
- 110 Byte Integer (B)

Destination Register field—Specifies the destination floating- point data register. If R/ M = 0 and the source and destination fields are equal, then the input operand is taken from the specified floating-point data register, and the result is then written into the same register. If the single register syntax is used, Motorola assemblers set the source and destination fields to the same value.

**MOTOROLA** 

Floating-Point Branch Conditionally (MC6888X, MC68040)

**FBcc** 

Operation: If Condition True

Then PC +  $d_n \rightarrow PC$ 

Assembler:

**Syntax:** FBcc. < size > , < label >

**Attributes:** Size = (Word, Long)

**Description:** If the specified floating-point condition is met, program execution continues at the location (PC) + displacement. The displacement is a twos-complement integer that counts the relative distance in bytes. The value of the program counter used to calculate the destination address is the address of the branch instruction plus two. If the displacement size is word, then a 16- bit displacement is stored in the word immediately following the instruction operation word. If the displacement size is long word, then a 32-bit displacement is stored in the two words immediately following the instruction operation word. The conditional specifier cc selects any one of the 32 floating- point conditional tests as described in **3.6.2 Conditional Testing**.

### Floating-Point Status Register:

Condition Codes: Not affected.

Quotient Byte: Not affected.

Exception Byte: BSUN Set if the NAN condition code is set and the

condition selected is an IEEE nonaware test.

SNAN Not Affected.
OPERR Not Affected.
OVF Not Affected.
UNFL Not Affected.
DZ Not Affected.
INEX2 Not Affected.
INEX1 Not Affected.

Accrued Exception Byte: The IOP bit is set if the BSUN bit is set in the exception

byte. No other bit is affected.

### **FBcc**

## Floating-Point Branch Conditionally (MC6888X, MC68040)

**FBcc** 

#### **Instruction Format:**

| 15                                                                 | 14 | 13 | 12 | 11  | 10          | 9   | 8 | 7 | 6    | 5                     | 4 | 3 | 2 | 1 | 0 |
|--------------------------------------------------------------------|----|----|----|-----|-------------|-----|---|---|------|-----------------------|---|---|---|---|---|
| 1                                                                  | 1  | 1  | 1  | COF | ROCES<br>ID | SOR | 0 | 1 | SIZE | CONDITIONAL PREDICATE |   |   |   |   |   |
| 16-BIT DISPLACEMENT OR MOST SIGNIFICANT WORD OF 32-BITDISPLACEMENT |    |    |    |     |             |     |   |   |      |                       |   |   |   |   |   |
| LEAST SIGNIFICANT WORD OF 32-BIT DISPLACEMENT (IF NEEDED)          |    |    |    |     |             |     |   |   |      |                       |   |   |   |   |   |

#### Instruction Fields:

Size field—Specifies the size of the signed displacement.

If Format = 0, then the displacement is 16 bits and is sign- extended before use.

If Format = 1, then the displacement is 32 bits.

Conditional Predicate field—Specifies one of 32 conditional tests as defined in **Table 3-23 Floating-Point Conditional Tests**.

#### **NOTE**

When a BSUN exception occurs, the main processor takes a preinstruction exception. If the exception handler returns without modifying the image of the program counter on the stack frame (to point to the instruction following the FBcc), then it must clear the cause of the exception (by clearing the NAN bit or disabling the BSUN trap), or the exception will occur again immediately upon return to the routine that caused the exception.

**FCMP** 

## Floating-Point Compare (MC6888X, MC68040)

**FCMP** 

**Operation:** FPn – Source

**Assembler** FCMP. < fmt > < ea > ,FPn

**Syntax:** FCMP.X FPm,FPn

**Attributes:** Format = (Byte, Word, Long, Single, Double, Extended, Packed)

**Description:** Converts the source operand to extended precision (if necessary) and subtracts the operand from the destination floating-point data register. The result of the subtraction is not retained, but it is used to set the floating-point condition codes as described in **3.6.2 Conditional Testing**.

**Operation Table:** The entries in this operation table differ from those of the tables describing most of the floating-point instructions. For each combination of input operand types, the condition code bits that may be set are indicated. If the name of a condition code bit is given and is not enclosed in brackets, then it is always set. If the name of a condition code bit is enclosed in brackets, then that bit is either set or cleared, as appropriate. If the name of a condition code bit is not given, then that bit is always cleared by the operation. The infinity bit is always cleared by the FCMP instruction since it is not used by any of the conditional predicate equations. Note that the NAN bit is not shown since NANs are always handled in the same manner (as described in **1.6.5 Not-A-Numbers**).

|             |   | SOURCE    |              |   |           |        |          |            |  |  |  |
|-------------|---|-----------|--------------|---|-----------|--------|----------|------------|--|--|--|
| DESTINATION |   | +         | In Range -   | + | Zero –    | +      | Infinity | _          |  |  |  |
| In Range    | + | {NZ}<br>N | none<br>{NZ} |   | none<br>N | N<br>N |          | none       |  |  |  |
| Zero<br>–   | + | N<br>N    | none<br>none |   | Z<br>NZ   | N      |          | none       |  |  |  |
| Infinity    | + | none<br>N | none<br>N    |   | none<br>N | Z<br>N | r        | none<br>NZ |  |  |  |

NOTE: If the source operand is a NAN, refer to 1.6.5 Not-A-Numbers for more information.

**FCMP** 

# Floating-Point Compare (MC6888X, MC68040)

**FCMP** 

### Floating-Point Status Register:

Condition Codes: Affected as described in the preceding operation table.

Quotient Byte: Not affected.

Exception Byte: BSUN Cleared

SNAN Refer to **1.6.5 Not-A-Numbers**.

OPERR Cleared
OVFL Cleared
UNFL Cleared
DZ Cleared
INEX2 Cleared

INEX1 If < fmt > is packed, refer to exception

processing in the appropriate user's manual;

cleared otherwise.

Accrued Exception Byte: Affected as described in exception processing in the appro-

priate user's manual.

#### **Instruction Format:**

| 1 | 5 | 14  | 13 | 12 | 11  | 10    | 9                 | 8 | / | 6     | 5 | 4    | 3       | 2     | 1   | 0 |
|---|---|-----|----|----|-----|-------|-------------------|---|---|-------|---|------|---------|-------|-----|---|
| 1 |   | 1   | 1  | 1  | COP | ROCES | SOR               | 0 | 0 | 0     |   | EF   | FECTIVE | ADDRE | ESS |   |
| ' |   | '   |    | '  |     | ID    |                   |   | 3 |       |   | MODE |         | R     | R   |   |
| C | ) | R/M | 0  | l  |     |       | STINATI<br>EGISTE |   | 0 | 0 0 1 |   | 1    | 1       | 0     | 0   |   |

## **FCMP**

# Floating-Point Compare (MC6888X, MC68040)

## **FCMP**

#### Instruction Fields:

Effective Address field—Determines the addressing mode for external operands.

If R/M = 0, this field is unused and should be all zeros.

If R/M = 1, specifies the location of the source operand location. Only data addressing modes can be used as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn*                     | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| – (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | 111  | 100      |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |
| ([bd,PC,Xn],od)         | 111  | 011      |
| ([bd,PC],Xn,od)         | 111  | 011      |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

R/M field—Specifies the source operand address mode.

- 0 The operation is register to register.
- 1 The operation is < ea > to register.

Source Specifier field—Specifies the source register or data format.

If R/M = 0, specifies the source floating-point data register.

If R/M = 1, specifies the source data format:

000 — Long-Word Integer (L)

001 — Single-Precision Real (S)

010 — Extended-Precision Real (X)

011 — Packed-Decimal Real (P)\*

100 — Word Integer (W)

101 — Double-Precision Real (D)

110 — Byte Integer (B)

Destination Register field—Specifies the destination floating- point data register.

<sup>\*</sup>This encoding in the MC68040 will cause an unimplemented data type exception to allow emulation in software.

FCOS Cosine (MC6888X, M68040FPSP)

**Operation:** Cosine of Source  $\rightarrow$  FPn

**Assembler** FCOS. < fmt > < ea > ,FPn

**Syntax:** FCOS.X FPm,FPn FCOS.X FPn

**Attributes:** Format = (Byte, Word, Long, Single, Double, Extended, Packed)

**Description:** Converts the source operand to extended precision (if necessary) and calculates the cosine of that number. Stores the result in the destination floating-point data register. This function is not defined for source operands of  $\pm$  infinity. If the source operand is not in the range of  $[-2\pi...+2\pi]$ , then the argument is reduced to within that range before the cosine is calculated. However, large arguments may lose accuracy during reduction, and very large arguments (greater than approximately  $10^{20}$ ) lose all accuracy. The result is in the range of [-1...+1].

### **Operation Table:**

|             |            | SOURCE <sup>1</sup> |                  |
|-------------|------------|---------------------|------------------|
| DESTINATION | + In Range | - + Zero            | + Infinity –     |
| Result      | Cosine     | + 1.0               | NAN <sup>2</sup> |

#### NOTES:

- 1. If the source operand is a NAN, refer to **1.6.5 Not-A-Numbers** for more information.
- 2. Sets the OPERR bit in the floating-point status register exception byte.

# FCOS Cosine (MC6888X, M68040FPSP)

### Floating-Point Status Register:

Condition Codes: Affected as described in **3.6.2 Conditional Testing**.

Quotient Byte: Not affected

Exception Byte: BSUN Cleared

SNAN Refer to **1.6.5 Not-A-Numbers**.

OPERR Set if the source operand is  $\pm$  infinity; cleared

otherwise.

OVFL Cleared UNFL Cleared DZ Cleared

INEX2 Refer to inexact result in the appropriate

user's manual.

INEX1 If < fmt > is packed, refer to inexact result on

decimal input in the appropriate user's

manual; cleared otherwise.

Accrued Exception Byte: Affected as described in IEEE exception and trap compati-

bility in the appropriate user's manual.

#### **Instruction Format:**

| 15 | 14  | 13 | 12 | 11  | 10          | 9 | 8                 | 7 | 6 | 5                 | 4    | 3 | 2 | 1       | 0 |  |
|----|-----|----|----|-----|-------------|---|-------------------|---|---|-------------------|------|---|---|---------|---|--|
| 1  | 1   | 1  | 1  | COF | COPROCESSOR |   |                   | 0 |   | EFFECTIVE ADDRESS |      |   |   |         |   |  |
| '  | '   | '  | '  |     | ID          |   |                   |   |   |                   | MODE |   | F | REGISTE | R |  |
| 0  | R/M | 0  |    |     |             |   | STINATI<br>EGISTE |   | 0 | 0                 | 1    | 1 | 1 | 0       | 1 |  |

#### Instruction Fields:

Coprocessor ID field—Specifies which coprocessor in the system is to execute this instruction. Motorola assemblers default to ID = 1 for the floating-point coprocessor.

**FCOS** 

# Cosine (MC6888X, M68040FPSP)

**FCOS** 

Effective Address field—Determines the addressing mode for external operands.

If R/M = 0, this field is unused and should contain zeros.

If R/M = 1, this field is encoded with an M68000 family addressing mode as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn*                     | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| - (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | 111  | 100      |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |
| ([bd,PC,Xn],od)         | 111  | 011      |
| ([bd,PC],Xn,od)         | 111  | 011      |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

R/M field—Specifies the source operand address mode.

- 0 The operation is register to register.
- 1 The operation is < ea > to register.

Source Specifier field—Specifies the source register or data format.

If R/M = 0, specifies the source floating-point data register.

If R/M = 1, specifies the source data format:

- 000 Long-Word Integer (L)
- 001 Single-Precision Real (S)
- 010 Extended-Precision Real (X)
- 011 Packed-Decimal Real (P)
- 100 Word Integer (W)
- 101 Double-Precision Real (D)
- 110 Byte Integer (B)

**FCOSH** 

Hyperbolic Cosine (MC6888X, M68040FPSP)

**FCOSH** 

**Operation:** Hyperbolic Cosine of Source  $\rightarrow$  FPn

**Assembler** FCOSH. < fmt > < ea > ,FPn

**Syntax:** FCOSH.X FPm,FPn FCOSH.X FPn

**Attributes:** Format = (Byte, Word, Long, Single, Double, Extended, Packed)

**Description:** Converts the source operand to extended precision (if necessary) and calculates the hyperbolic cosine of that number. Stores the result in the destination floating-point data register.

#### **Operation Table:**

|             | SOURCE            |          |              |  |  |  |  |  |  |  |
|-------------|-------------------|----------|--------------|--|--|--|--|--|--|--|
| DESTINATION | + In Range -      | + Zero - | + Infinity - |  |  |  |  |  |  |  |
| Result      | Hyperbolic Cosine | + 1.0    | + inf        |  |  |  |  |  |  |  |

NOTE: If the source operand is a NAN, refer to 1.6.5 Not-A-Numbers for more information.

#### Floating-Point Status Register:

Condition Codes: Affected as described in **3.6.2 Conditional Testing.** 

Quotient Byte: Not affected.

Exception Byte: BSUN Cleared

SNAN Refer to **1.6.5 Not-A-Numbers**.

OPERR Cleared

OVFL Refer to overflow in the appropriate user's

manual.

UNFL Cleared DZ Cleared

INEX2 Refer to inexact result in the appropriate

user's manual.

INEX1 If < fmt > is packed, refer to inexact result on

decimal input in the appropriate user's

manual; cleared otherwise.

Accrued Exception Byte: Affected as described in IEEE exception and trap compati-

bility in the appropriate user's manual.

**FCOSH** 

# Hyperbolic Cosine (MC6888X, M68040FPSP)

**FCOSH** 

#### **Instruction Format:**

|   | 15 | 14  | 13 | 12 | 11  | 10        | 9 | 8                  | 7 | 6 | 5                 | 4 | 3 | 2 | 1 | 0 |  |
|---|----|-----|----|----|-----|-----------|---|--------------------|---|---|-------------------|---|---|---|---|---|--|
| Γ | 1  | 1   | 1  | 1  | COF | PROCESSOR |   | 0                  | 0 | _ | EFFECTIVE ADDRESS |   |   |   |   |   |  |
|   | '  | '   | '  | '  |     | ID        |   | 0                  | 0 | 0 | MODE REGISTER     |   |   |   |   | R |  |
|   | 0  | R/M | 0  |    |     |           |   | STINATI<br>REGISTE |   | 0 | 0                 | 1 | 1 | 1 | 0 | 1 |  |

#### **Instruction Fields:**

Coprocessor ID field—Specifies which coprocessor in the system is to execute this instruction. Motorola assemblers default to ID = 1 for the floating-point coprocessor.

Effective Address field—Determines the addressing mode for external operands.

If R/M = 0, this field is unused and should be all zeros.

If R/M = 1, this field is encoded with an M68000 family addressing mode as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn*                     | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| - (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | 111  | 100      |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |
| ([bd,PC,Xn],od)         | 111  | 011      |
| ([bd,PC],Xn,od)         | 111  | 011      |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

## **FCOSH**

# Hyperbolic Cosine (MC6888X, M68040FPSP)

**FCOSH** 

R/M field—Specifies the source operand address mode.

- 0 The operation is register to register.
- 1 The operation is < ea > to register.

Source Specifier field—Specifies the source register or data format.

If R/M = 0, specifies the source floating-point data register.

If R/M = 1, specifies the source data format:

000 — Long-Word Integer (L)

001 — Single-Precision Real (S)

010 — Extended-Precision Real (X)

011 — Packed-Decimal Real (P)

100 — Word Integer (W)

101 — Double-Precision Real (D)

110 — Byte Integer (B)

FDBCC Floating-Point Test Condition,
Decrement, and Branch

**FDBcc** 

**Operation:** If Condition True

Then No Operation

Else  $Dn - 1 \rightarrow Dn$ 

If  $Dn \neq -1$ 

Then PC +  $d_n \rightarrow PC$ Else Execute Next Instruction

**Assembler** 

**Syntax:** FDBcc Dn, < label >

Attributes: Unsized

**Description:** This instruction is a looping primitive of three parameters: a floating-point condition, a counter (data register), and a 16-bit displacement. The instruction first tests the condition to determine if the termination condition for the loop has been met, and if so, execution continues with the next instruction in the instruction stream. If the termination condition is not true, the low-order 16 bits of the counter register are decremented by one. If the result is – 1, the count is exhausted, and execution continues with the next instruction. If the result is not equal to – 1, execution continues at the location specified by the current value of the program counter plus the sign-extended 16-bit displacement. The value of the program counter used in the branch address calculation is the address of the displacement word.

(MC6888X, MC68040)

The conditional specifier cc selects any one of the 32 floating- point conditional tests as described in **3.6.2 Conditional Testing**.

### Floating-Point Status Register:

Condition Codes: Not affected.

Quotient Byte: Not affected.

Exception Byte: BSUN Set if the NAN condition code is set and the

condition selected is an IEEE nonaware test.

SNAN Not Affected.
OPERR Not Affected.
OVFL Not Affected.
UNFL Not Affected.
DZ Not Affected.
NEX2 Not Affected.
NEX1 Not Affected.

Accrued Exception Byte: The IOP bit is set if the BSUN bit is set in the exception

byte. No other bit is affected.

## **FDBcc**

## Floating-Point Test Condition, Decrement, and Branch (MC6888X, MC68040)

## **FDBcc**

#### **Instruction Format:**

| 15 | 14                  | 13 | 12 | 11                | 10 | 9 | 8 | 7 | 6 | 5                     | 4 | 3 | 2                 | 2 1 |   |
|----|---------------------|----|----|-------------------|----|---|---|---|---|-----------------------|---|---|-------------------|-----|---|
| 1  | 1                   | 1  | 1  | COPROCESSOR<br>ID |    |   | 0 | 0 | 1 | 0                     | 0 | 1 | COUNT<br>REGISTER |     | R |
| 0  | 0                   | 0  | 0  | 0                 | 0  | 0 | 0 | 0 | 0 | CONDITIONAL PREDICATE |   |   |                   |     |   |
|    | 16-BIT DISPLACEMENT |    |    |                   |    |   |   |   |   |                       |   |   |                   |     |   |

#### **Instruction Fields:**

Count Register field—Specifies data register that is used as the counter.

Conditional Predicate field—Specifies one of the 32 floating-point conditional tests as described in **3.6.2 Conditional Testing**.

Displacement field—Specifies the branch distance (from the address of the instruction plus two) to the destination in bytes.

#### NOTE

The terminating condition is like that defined by the UNTIL loop constructs of high-level languages. For example: FDBOLT can be stated as "decrement and branch until ordered less than".

There are two basic ways of entering a loop: at the beginning or by branching to the trailing FDBcc instruction. If a loop structure terminated with FDBcc is entered at the beginning, the control counter must be one less than the number of loop executions desired. This count is useful for indexed addressing modes and dynamically specified bit operations. However, when entering a loop by branching directly to the trailing FDBcc instruction, the count should equal the loop execution count. In this case, if the counter is zero when the loop is entered, the FDBcc instruction does not branch, causing a complete bypass of the main loop.

When a BSUN exception occurs, a preinstruction exception is taken by the main processor. If the exception handler returns without modifying the image of the program counter on the stack frame (to point to the instruction following the FDBcc), then it must clear the cause of the exception (by clearing the NAN bit or disabling the BSUN trap), or the exception will occur again immediately upon return to the routine that caused the exception.

FDIV Floating-Point Divide (MC6888X, MC68040)

**FDIV** 

**Operation:**  $FPn \div Source \rightarrow FPn$ 

**Assembler** FDIV. < fmt > < ea > ,FPn

**Syntax:** FDIV.X FPm,FPn

\*FrDIV. < fmt > < ea > ,FPn

\*FrDIV.X FPm,FPn

where r is rounding precision, S or D

\*Supported by MC68040 only

**Attributes:** Format = (Byte, Word, Long, Single, Double, Extended, Packed)

**Description:** Converts the source operand to extended precision (if necessary) and divides that number into the number in the destination floating-point data register. Stores the result in the destination floating-point data register.

FDIV will round the result to the precision selected in the floating-point control register. FSDIV and FDDIV will round the result to single or double precision, respectively, regardless of the rounding precision selected in the floating-point control register.

### **Operation Table:**

|             |   |                |          |                | ;                                        | SOURCE <sup>1</sup> |                                          |                |          |                |
|-------------|---|----------------|----------|----------------|------------------------------------------|---------------------|------------------------------------------|----------------|----------|----------------|
| DESTINATION |   | +              | In Range | _              | +                                        | Zero                | _                                        | +              | Infinity | _              |
| In Range    | + |                | Divide   |                | + inf <sup>2</sup><br>– inf <sup>2</sup> |                     | – inf <sup>2</sup><br>+ inf <sup>2</sup> | + 0.0<br>- 0.0 |          | - 0.0<br>+ 0.0 |
| Zero        |   | + 0.0<br>- 0.0 |          | + 0.0<br>+ 0.0 |                                          | NAN <sup>3</sup>    |                                          | + 0.0<br>- 0.0 |          | - 0.0<br>+ 0.0 |
| Infinity    | + | + inf<br>– inf |          | – inf<br>+ inf | + inf<br>– inf                           |                     | – inf<br>+ inf                           |                | NAN‡     |                |

#### NOTES:

- 1. If the source operand is a NAN, refer to 1.6.5 Not-A-Numbers for more information.
- 2. Sets the DZ bit in the floating-point status register exception byte.
- 3. Sets the OPERR bit in the floating-point status register exception byte.

## **FDIV**

# Floating-Point Divide (MC6888X, MC68040)

## **FDIV**

### Floating-Point Status Register:

Condition Codes: Affected as described in **3.6.2 Conditional Testing**.

Quotient Byte: Not affected.

Exception Byte: BSUN Cleared

SNAN Refer to **1.6.5 Not-A-Numbers**.

OPERR Set for  $0 \div 0$  or infinity  $\div$  infinity; cleared

otherwise.

OVFL Refer to exception processing in the

appropriate user's manual.

UNFL Refer to exception processing in the

appropriate user's manual.

DZ Set if the source is zero and the destination is

in range; cleared otherwise.

INEX2 Refer to exception processing in the

appropriate user's manual.

INEX1 If < fmt > is packed, refer to exception

processing in the appropriate user's manual;

cleared otherwise.

Accrued Exception Byte: Affected as described in exception processing in the appro-

priate user's manual.

#### **Instruction Format:**

|   | 15 | 14  | 13 | 12 | 11                | 10    | 9                    | 8 | 7 | 6 | 5 | 4    | 3      | 2     | 1       | 0 |
|---|----|-----|----|----|-------------------|-------|----------------------|---|---|---|---|------|--------|-------|---------|---|
| Γ | 4  | 1   | 1  | 1  | COF               | ROCES | SOR                  | R |   | 0 |   | EFF  | ECTIVE | ADDRE | ESS     |   |
|   | '  | '   | '  | '  |                   | ID    |                      | " | " | 0 |   | MODE |        | R     | REGISTE | R |
|   | 0  | R/M | 0  |    | SOURCE<br>PECIFIE |       | DESTINATION REGISTER |   |   |   |   | (    | PMOD   | E     |         |   |

**FDIV** 

# Floating-Point Divide (MC6888X, MC68040)

**FDIV** 

#### **Instruction Fields:**

Effective Address field—Determines the addressing mode for external operands.

If R/M = 0, this field is unused and should be all zeros.

If R/M = 1, specifies the location of the source operand location. Only data addressing modes can be used as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn*                     | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| – (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | 111  | 100      |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |
| ([bd,PC,Xn],od)         | 111  | 011      |
| ([bd,PC],Xn,od)         | 111  | 011      |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

R/M field—Specifies the source operand address mode.

- 0 The operation is register to register.
- 1 The operation is < ea > to register.

Source Specifier field—Specifies the source register or data format.

If R/M = 0, specifies the source floating-point data register.

If R/M = 1, specifies the source data format:

- 000 Long-Word Integer (L)
- 001 Single-Precision Real (S)
- 010 Extended-Precision Real (X)
- 011 Packed-Decimal Real (P)\*
- 100 Word Integer (W)
- 101 Double-Precision Real (D)
- 110 Byte Integer (B)

<sup>\*</sup>This encoding in the MC68040 will cause an unimplemented data type exception to allow emulation in software.

**FDIV** 

# Floating-Point Divide (MC6888X, MC68040)

**FDIV** 

Destination Register field—Specifies the destination floating- point data register. Opmode field—Specifies the instruction and rounding precision.

| 0100000 FDIV  | Rounding precision specified by the floating- point control register. |
|---------------|-----------------------------------------------------------------------|
| 1100000 FSDIV | Single-precision rounding specified.                                  |
| 1100100 FDDIV | Double-precision rounding specified.                                  |

FETOX e<sup>x</sup> FETOX

(MC6888X, M68040FPSP)

**Operation:**  $e^{Source} \rightarrow FPn$ 

**Assembler** FETOX. < fmt > < ea > ,FPn

**Syntax:** FETOX.X FPm,FPn **Syntax:** FETOX.X FPn

**Attributes:** Format = (Byte, Word, Long, Single, Double, Extended, Packed)

**Description:** Converts the source operand to extended precision (if necessary) and calculates e to the power of that number. Stores the result in the destination floating-point data register.

### **Operation Table:**

|             |                | SOURCE |        |       |            |  |  |  |  |
|-------------|----------------|--------|--------|-------|------------|--|--|--|--|
| DESTINATION | + In Range     | - +    | Zero – | +     | Infinity – |  |  |  |  |
| Result      | e <sup>x</sup> |        | + 1.0  | + inf | +0.0       |  |  |  |  |

NOTE: If the source operand is a NAN, refer to 1.6.5 Not-A-Numbers for more information.

### Floating-Point Status Register:

Condition Codes: Affected as described in **3.6.2 Conditional Testing**.

Quotient Byte: Not affected.

Exception Byte: BSUN Cleared

SNAN Refer to **1.6.5 Not-A-Numbers**.

OPERR Cleared

OVFL Refer to overflow in the appropriate user's

manual.

UNFL Refer to underflow in the appropriate user's

manual.

DZ Cleared

INEX2 Refer to inexact result in the appropriate

user's manual.

INEX1 If < fmt > is packed, refer to inexact result on

decimal input in the appropriate user's

manual; cleared otherwise.

Accrued Exception Byte: Affected as described in IEEE exception and trap compati-

bility in the appropriate user's manual.

## **FETOX**

## e<sup>X</sup> (MC6888X, M68040FPSP)

## **FETOX**

#### **Instruction Format:**

| 15 | 14  | 13 | 12 | 11                | 10    | 9                       | 8 | 7   | 6 | 5 | 4    | 3 | 2  | 1       | 0     |     |  |
|----|-----|----|----|-------------------|-------|-------------------------|---|-----|---|---|------|---|----|---------|-------|-----|--|
| 1  | 1   | 1  | 1  | COP               | ROCES | SOR                     | 0 | 0 0 |   |   | _    |   | EF | FECTIVE | ADDRE | ESS |  |
| '  | '   | '  | '  |                   | ID    |                         | " | "   | " |   | MODE |   | F  | REGISTE | R     |     |  |
| 0  | R/M | 0  |    | SOURCE<br>PECIFIE |       | DESTINATION<br>REGISTER |   |     | 0 | 0 | 0    | 1 | 1  | 0       | 0     |     |  |

#### **Instruction Fields:**

Coprocessor ID field—Specifies which coprocessor in the system is to execute this instruction. Motorola assemblers default to ID = 1 for the floating-point coprocessor.

Effective Address field—Determines the addressing mode for external operands.

If R/M = 0, this field is unused and should be all zeros.

If R/M = 1, this field is encoded with an M68000 family addressing mode as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn*                     | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| - (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | 111  | 100      |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |
| ([bd,PC,Xn],od)         | 111  | 011      |
| ([bd,PC],Xn,od)         | 111  | 011      |
|                         |      |          |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

FETOX e<sup>x</sup> FETOX (MC6888X, M68040FPSP)

R/M field—Specifies the source operand address mode.

- 0 The operation is register to register.
- 1 The operation is < ea > to register.

Source Specifier Field—Specifies the source register or data format.

If R/M = 0, specifies the source floating-point data register.

If R/M = 1, specifies the source data format:

- 000 Long-Word Integer (L)
- 001 Single-Precision Real (S)
- 010 Extended-Precision Real (X)
- 011 Packed-Decimal Real (P)\*
- 100 Word Integer (W)
- 101 Double-Precision Real (D)
- 110 Byte Integer (B)

## FETOXM1

e<sup>x</sup> – 1

FETOXM1

(MC6888X, M68040FPSP)

**Operation:**  $e^{\text{Source}} - 1 \rightarrow \text{FPn}$ 

**Assembler** FETOXM1. < fmt > < ea > ,FPn

**Syntax:** FETOXM1.X FPm,FPn

FETOXM1.X FPn

**Attributes:** Format = (Byte, Word, Long, Single, Double, Extended, Packed)

**Description:** Converts the source operand to extended precision (if necessary) and calculates e to the power of that number. Subtracts one from the value and stores the result in the destination floating-point data register.

### **Operation Table:**

|             |   | SOURCE             |   |       |      |       |       |          |      |
|-------------|---|--------------------|---|-------|------|-------|-------|----------|------|
| DESTINATION | + | In Range           | _ | +     | Zero | -     | +     | Infinity | -    |
| Result      |   | e <sup>x</sup> – 1 |   | + 0.0 |      | - 0.0 | + inf |          | -1.0 |

NOTE: If the source operand is a NAN, refer to 1.6.5 Not-A-Numbers for more information.

#### Floating-Point Status Register:

Condition Codes: Affected as described in **3.6.2 Conditional Testing**.

Quotient Byte: Not affected.

Exception Byte: BSUN Cleared

SNAN Refer to **1.6.5 Not-A-Numbers**.

OPERR Cleared

OVFL Refer to overflow in the appropriate user's

manual.

UNFL Refer to underflow in the appropriate user's

manual.

DZ Cleared

INEX2 Refer to inexact result in the appropriate

user's manual.

INEX1 If < fmt > is packed, refer to inexact result on

decimal input in the appropriate user's

manual; cleared otherwise.

Accrued Exception Byte: Affected as described in IEEE exception and trap compati-

bility in the appropriate user's manual.

FETOXM1

# $e^{x} - 1$ (MC6888X, M68040FPSP)

## FETOXM1

#### **Instruction Format:**

| 15 | 14  | 13 | 12 | 11                | 10     | 9   | 8                       | 7 | 6 | 5 | 4    | 3       | 2       | 1      | 0 |
|----|-----|----|----|-------------------|--------|-----|-------------------------|---|---|---|------|---------|---------|--------|---|
| 1  | 1   | 1  | 1  | COF               | PROCES | SOR | 0                       | 0 | _ |   | EF   | FECTIVE | E ADDRE | SS     |   |
| '  | '   | '  | '  |                   | ID     |     | 0                       | " | " |   | MODE |         | R       | EGISTE | R |
| 0  | R/M | 0  |    | SOURCE<br>PECIFIE |        |     | DESTINATION<br>REGISTER |   | 0 | 0 | 0    | 1       | 1       | 0      | 0 |

#### **Instruction Fields:**

Coprocessor ID field—Specifies which coprocessor in the system is to execute this instruction. Motorola assemblers default to ID = 1 for the floating-point coprocessor.

Effective Address field—Determines the addressing mode for external operands.

If R/M = 0, this field is unused and should be all zeros.

If R/M = 1, this field is encoded with an M68000 family addressing mode as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn*                     | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| – (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | 111  | 100      |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |
| ([bd,PC,Xn],od)         | 111  | 011      |
| ([bd,PC],Xn,od)         | 111  | 011      |
|                         |      |          |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

## FETOXM1

# $e^{x} - 1$ (MC6888X, M68040FPSP)

## FETOXM1

R/M field—Specifies the source operand address mode.

- 0 The operation is register to register.
- 1 The operation is < ea > to register.

Source Specifier Field—Specifies the source register or data format.

If R/M = 0, specifies the source floating-point data register.

If R/M = 1, specifies the source data format:

000 — Long-Word Integer (L)

001 — Single-Precision Real (S)

010 — Extended-Precision Real (X)

011 — Packed-Decimal Real (P)

100 — Word Integer (W)

101 — Double-Precision Real (D)

110 — Byte Integer (B)

**FGETEXP** 

Get Exponent (MC6888X, M68040FPSP)

**FGETEXP** 

**Operation:** Exponent of Source  $\rightarrow$  FPn

**Assembler** FGETEXP. < fmt > < ea > ,FPn

**Syntax:** FGETEXP.X FPm,FPn

FGETEXP.X FPn

**Attributes:** Format = (Byte, Word, Long, Single, Double, Extended, Packed)

**Description:** Converts the source operand to extended precision (if necessary) and extracts the binary exponent. Removes the exponent bias, converts the exponent to an extended-precision floating- point number, and stores the result in the destination floating- point data register.

### **Operation Table:**

|             |   |          |   |       | SOURCE1 |       |   |                  |   |
|-------------|---|----------|---|-------|---------|-------|---|------------------|---|
| DESTINATION | + | In Range | - | +     | Zero    | _     | + | Infinity         | _ |
| Result      |   | Exponent |   | + 0.0 |         | - 0.0 |   | NAN <sup>2</sup> |   |

#### NOTES:

1. If the source operand is a NAN, refer to 1.6.5 Not-A-Numbers for more information.

2. Sets the OPERR bit in the floating-point status register exception byte.

### Floating-Point Status Register:

Condition Codes: Affected as described in **3.6.2 Conditional Testing**.

Quotient Byte: Not affected.

Exception Byte: BSUN Cleared

SNAN Refer to **1.6.5 Not-A-Numbers**.

OPERR Set if the source is  $\pm$  infinity; cleared

otherwise.

OVFL Cleared UNFL Cleared DZ Cleared INEX2 Cleared

INEX1 If < fmt > is packed, refer to inexact result on

decimal input in the appropriate user's

manual; cleared otherwise.

Accrued Exception Byte: Affected as described in IEEE exception and trap compati-

bility in the appropriate user's manual.

## **FGETEXP**

# Get Exponent (MC6888X, M68040FPSP)

## **FGETEXP**

#### **Instruction Format:**

|   | 15 | 14  | 13 | 12 | 11                | 10          | 9   | 8                  | 7 | 6 | 5 | 4    | 3 | 2 | 1       | 0 |
|---|----|-----|----|----|-------------------|-------------|-----|--------------------|---|---|---|------|---|---|---------|---|
| Г | 4  | 1   | 1  | 1  | COPROCESSOR 0 0   | COPROCESSOR |     | EFFECTIVE ADDRESS  |   |   |   |      |   |   |         |   |
|   | '  | '   | '  | '  |                   | ID          |     | "                  | " | " |   | MODE |   | F | REGISTE | R |
|   | 0  | R/M | 0  |    | SOURCE<br>PECIFIE |             | l . | STINATI<br>REGISTE | - | 0 | 0 | 1    | 1 | 1 | 1       | 0 |

#### **Instruction Fields:**

Coprocessor ID field—Specifies which coprocessor in the system is to execute this instruction. Motorola assemblers default to ID = 1 for the floating-point coprocessor.

Effective Address field—Determines the addressing mode for external operands.

If R/M = 0, this field is unused and should be all zeros.

If R/M = 1, this field is encoded with an M68000 family addressing mode as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn*                     | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| – (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | 111  | 100      |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |
| ([bd,PC,Xn],od)         | 111  | 011      |
| ([bd,PC],Xn,od)         | 111  | 011      |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

R/M field—Specifies the source operand address mode.

- 0 The operation is register to register.
- 1 The operation is < ea > to register.

**FGETEXP** 

# Get Exponent (MC6888X, M68040FPSP)

**FGETEXP** 

Source Specifier field—Specifies the source register or data format.

If R/M = 0, specifies the source floating-point data register.

If R/M = 1, specifies the source data format:

000 — Long-Word Integer (L)

001 — Single-Precision Real (S)

010 — Extended-Precision Real (X)

011 — Packed-Decimal Real (P)

100 — Word Integer (W)

101 — Double-Precision Real (D)

110 — Byte Integer (B)

# **FGETMAN**

### Get Mantissa (MC6888X, M68040FPSP)

## **FGETMAN**

**Operation:** Mantissa of Source  $\rightarrow$  FPn

**Assembler** FGETMAN. < fmt > < ea > ,FPn

**Syntax:** FGETMAN.X FPm,FPn

FGETMAN.X FPn

**Attributes:** Format = (Byte, Word, Long, Single, Double, Extended, Packed)

**Description:** Converts the source operand to extended precision (if necessary) and extracts the mantissa. Converts the mantissa to an extended-precision value and stores the result in the destination floating-point data register. The result is in the range [1.0...2.0] with the sign of the source mantissa, zero, or a NAN.

### **Operation Table:**

|             |   |          |   |       | SOURCE1 |       |   |                  |   |
|-------------|---|----------|---|-------|---------|-------|---|------------------|---|
| DESTINATION | + | In Range | - | +     | Zero    | _     | + | Infinity         | _ |
| Result      |   | Mantissa |   | + 0.0 |         | - 0.0 |   | NAN <sup>2</sup> |   |

#### NOTES:

1. If the source operand is a NAN, refer to 1.6.5 Not-A-Numbers for more information.

2. Sets the OPERR bit in the floating-point status register exception byte.

### Floating-Point Status Register:

Condition Codes: Affected as described in **3.6.2 Conditional Testing**.

Quotient Byte: Not affected.

Exception Byte: BSUN Cleared

SNAN Refer to **1.6.5 Not-A-Numbers**.

OPERR Set if the source is  $\pm$  infinity; cleared

otherwise.

OVFL Cleared UNFL Cleared DZ Cleared INEX2 Cleared

INEX1 If < fmt > is packed, refer to inexact result on

decimal input in the appropriate user's

manual; cleared otherwise.

Accrued Exception Byte: Affected as described in IEEE exception and trap compati-

bility in the appropriate user's manual.

## **FGETMAN**

### Get Mantissa (MC6888X, M68040FPSP)

## **FGETMAN**

#### **Instruction Format:**

|   | 15 | 14  | 13 | 12 | 11                | 10 | 9           | 8                  | 7 | 6 | 5 | 4    | 3 | 2 | 1       | 0 |
|---|----|-----|----|----|-------------------|----|-------------|--------------------|---|---|---|------|---|---|---------|---|
| Γ | 1  | 1   | 1  | 1  | COPROCESSOR       |    | COPROCESSOR | EFFECTIVE ADDRESS  |   |   |   |      |   |   |         |   |
|   | ı  | !   | '  | '  |                   | ID |             | 0                  | " | " |   | MODE |   | F | REGISTE | R |
|   | 0  | R/M | 0  |    | SOURCE<br>PECIFIE |    |             | STINATI<br>REGISTE |   | 0 | 0 | 1    | 1 | 1 | 1       | 1 |

#### Instruction Fields:

Coprocessor ID field—Specifies which coprocessor in the system is to execute this instruction. Motorola assemblers default to ID = 1 for the floating-point coprocessor.

Effective Address field—Determines the addressing mode for external operands.

If R/M = 0, this field is unused and should be all zeros.

If R/M = 1, this field is encoded with an M68000 family addressing mode as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn*                     | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| - (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | 111  | 100      |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |
| ([bd,PC,Xn],od)         | 111  | 011      |
| ([bd,PC],Xn,od)         | 111  | 011      |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

R/M field—Specifies the source operand address mode.

- 0 The operation is register to register.
- 1 The operation is < ea > to register.

## **FGETMAN**

# Get Mantissa (MC6888X, M68040FPSP)

# **FGETMAN**

Source Specifier field—Specifies the source register or data format.

If R/M = 0, specifies the source floating-point data register.

If R/M = 1, specifies the source data format:

000 — Long-Word Integer (L)

001 — Single-Precision Real (S)

010 — Extended-Precision Real (X)

011 — Packed-Decimal Real (P)

100 — Word Integer (W)

101 — Double-Precision Real (D)

110 — Byte Integer (B)

FINT Integer Part (MC6888X, M68040FPSP)

**Operation:** Integer Part of Source → FPn

**Assembler** FINT. < fmt > < ea > ,FPn

**Syntax:** FINT.X FPm,FPn

FINT.X FPn

**Attributes:** Format = (Byte, Word, Long, Single, Double, Extended, Packed)

**Description:** Converts the source operand to extended precision (if necessary), extracts the integer part, and converts it to an extended-precision floating-point number. Stores the result in the destination floating-point data register. The integer part is extracted by rounding the extended-precision number to an integer using the current rounding mode selected in the floating-point control register mode control byte. Thus, the integer part returned is the number that is to the left of the radix point when the exponent is zero, after rounding. For example, the integer part of 137.57 is 137.0 for the round-to-zero and round-to-negative infinity modes and 138.0 for the round-to-nearest and round-to-positive infinity modes. Note that the result of this operation is a floating-point number.

#### **Operation Table:**

|             |   |          |   |       | SOURCE |       |   |             |   |
|-------------|---|----------|---|-------|--------|-------|---|-------------|---|
| DESTINATION | + | In Range | - | +     | Zero   | _     | + | Infinity    | _ |
| Result      |   | Integer  |   | + 0.0 |        | - 0.0 |   | + inf – inf |   |

NOTE: If the source operand is a NAN, refer to 1.6.5 Not-A-Numbers for more information.

## **FINT**

# Integer Part (MC6888X, M68040FPSP)

## **FINT**

### Floating-Point Status Register:

Condition Codes: Affected as described in **3.6.2 Conditional Testing**.

Quotient Byte: Not affected.

Exception Byte: BSUN Cleared

SNAN Refer to **1.6.5 Not-A-Numbers**.

OPERR Cleared
OVFL Cleared
UNFL Cleared
DZ Cleared

INEX2 Refer to inexact result in the appropriate

user's manual.

INEX1 If < fmt > is packed, refer to inexact result on

decimal input in the appropriate user's

manual; cleared otherwise.

Accrued Exception Byte: Affected as described in IEEE exception and trap compati-

bility in the appropriate user's manual.

#### **Instruction Format:**

| 15 | 14  | 13 | 12 | 11     | 10           | 9   | 8                 | 7 | 6 | 5 | 4           | 3       | 2 | 1              | 0 |
|----|-----|----|----|--------|--------------|-----|-------------------|---|---|---|-------------|---------|---|----------------|---|
| 1  | 1   | 1  | 1  | COF    | PROCES<br>ID | SOR | 0                 | 0 | 0 |   | EFI<br>MODE | FECTIVE |   | ESS<br>REGISTE | R |
| 0  | R/M | 0  |    | SOURCE |              |     | STINATI<br>EGISTE |   | 0 | 0 | 0           | 0       | 0 | 0              | 1 |

#### **Instruction Fields:**

Coprocessor ID field—Specifies which coprocessor in the system is to execute this instruction. Motorola assemblers default to ID = 1 for the floating-point coprocessor.

**FINT** 

# Integer Part (MC6888X, M68040FPSP)

**FINT** 

Effective Address field—Determines the addressing mode for external operands.

If R/M = 0, this field is unused and should be all zeros.

If R/M = 1, this field is encoded with an M68000 family addressing mode as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn*                     | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| – (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | 111  | 100      |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |
| ([bd,PC,Xn],od)         | 111  | 011      |
| ([bd,PC],Xn,od)         | 111  | 011      |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

R/M field—Specifies the source operand address mode.

- 0 The operation is register to register.
- 1 The operation is < ea > to register.

Source Specifier field—Specifies the source register or data format.

If R/M = 0, specifies the source floating-point data register.

If R/M = 1, specifies the source data format:

000 — Long-Word Integer (L)

001 — Single-Precision Real (S)

010 — Extended-Precision Real (X)

011 — Packed-Decimal Real (P)

100 — Word Integer (W)

101 — Double-Precision Real (D)

110 — Byte Integer (B)

**FINTRZ** 

Integer Part, Round-to-Zero (MC6888X, M68040FPSP)

**FINTRZ** 

**Operation:** Integer Part of Source  $\rightarrow$  FPn

**Assembler** FINTRZ. < fmt > < ea > ,FPn

Syntax: FINTRZ.X FPm,FPn FINTRZ.X FPn

**Attributes:** Format = (Byte, Word, Long, Single, Double, Extended, Packed)

**Description:** Converts the source operand to extended precision (if necessary) and extracts the integer part and converts it to an extended-precision floating-point number. Stores the result in the destination floating-point data register. The integer part is extracted by rounding the extended-precision number to an integer using the round-to-zero mode, regardless of the rounding mode selected in the floating-point control register mode control byte (making it useful for FORTRAN assignments). Thus, the integer part returned is the number that is to the left of the radix point when the exponent is zero. For example, the integer part of 137.57 is 137.0; the integer part of 0.1245 x 102 is 12.0. Note that the result of this operation is a floating-point number.

#### **Operation Table:**

|             | SOURCE                            |       |        |       |          |      |  |  |  |  |
|-------------|-----------------------------------|-------|--------|-------|----------|------|--|--|--|--|
| DESTINATION | + In Range                        | - +   | Zero - | +     | Infinity | _    |  |  |  |  |
| Result      | Integer, Forced<br>Round-to- Zero | + 0.0 | - 0.0  | + inf |          | -inf |  |  |  |  |

NOTE: If the source operand is a NAN, refer to 1.6.5 Not-A-Numbers for more information.

**FINTRZ** 

# Integer Part, Round-to-Zero (MC6888X, M68040FPSP)

**FINTRZ** 

### Floating-Point Status Register:

Condition Codes: Affected as described in **3.6.2 Conditional Testing**.

Quotient Byte: Not affected.

Exception Byte: BSUN Cleared

SNAN Refer to **1.6.5 Not-A-Numbers**.

OPERR Cleared
OVFL Cleared
UNFL Cleared
DZ Cleared

INEX2 Refer to inexact result in the appropriate

user's manual.

INEX1 If < fmt > is packed, refer to inexact result on

decimal input in the appropriate user's

manual; cleared otherwise.

Accrued Exception Byte: Affected as described in IEEE exception and trap compati-

bility in the appropriate user's manual.

#### **Instruction Format:**

| 15 | 14  | 13 | 12 | 11          | 10 | 9                   | 8        | 7         | 6     | 5    | 4    | 3 | 2 | 1       | 0       |       |     |  |
|----|-----|----|----|-------------|----|---------------------|----------|-----------|-------|------|------|---|---|---------|---------|-------|-----|--|
| 1  | 1   | 1  | 1  | COPROCESSOR |    |                     | COPROCES | ESSOR 0 0 | 0 0   | OR 0 |      | _ |   | EF      | FECTIVE | ADDRE | ESS |  |
| '  | !   | '  | '  |             | ID |                     | "        | 0   0     | 0   0 |      | MODE |   | F | REGISTE | R       |       |     |  |
| 0  | R/M | 0  |    | SOURCE      |    | DESTINATION REGISTE |          |           | 0     | 0    | 0    | 0 | 0 | 1       | 1       |       |     |  |

#### **Instruction Fields:**

Coprocessor ID field—Specifies which coprocessor in the system is to execute this instruction. Motorola assemblers default to ID = 1 for the floating-point coprocessor.

# **FINTRZ**

# Integer Part, Round-to-Zero (MC6888X, M68040FPSP)

**FINTRZ** 

Effective Address field—Determines the addressing mode for external operands.

If R/M = 0, this field is unused and should be all zeros.

If R/M = 1, this field is encoded with an M68000 family addressing mode as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn*                     | 000  | reg. number:Dn |
| An                      |      | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| – (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | 111  | 100      |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |
| ([bd,PC,Xn],od)         | 111  | 011      |
| ([bd,PC],Xn,od)         | 111  | 011      |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

R/M field—Specifies the source operand address mode.

0 — The operation is register to register.

1 — The operation is < ea > to register.

Source Specifier field—Specifies the source register or data format.

If R/M = 0, specifies the source floating-point data register.

If RM = 1, specifies the source data format:

000 — Long-Word Integer (L)

001 — Single-Precision Real (S)

010 — Extended-Precision Real (X)

011 — Packed-Decimal Real (P)

100 — Word Integer (W)

101 — Double-Precision Real (D)

110 — Byte Integer (B)

FLOG<sub>10</sub>

Log<sub>10</sub> (MC6888X, M68040FPSP) FLOG<sub>10</sub>

**Operation:** Log<sub>10</sub> of Source  $\rightarrow$  FPn

**Assembler** FLOG10. < fmt > < ea > ,FPn

**Syntax:** FLOG10.X FPm,FPn

FLOG10.X FPn

**Attributes:** Format = (Byte, Word, Long, Single, Double, Extended, Packed)

**Description:** Convert the source operand to extended precision (if necessary) and calculates the logarithm of that number using base 10 arithmetic. Stores the result in the destination floating-point data register. This function is not defined for input values less than zero.

### **Operation Table:**

|             |                   | SOURCE <sup>1</sup> |   |                    |   |       |          |                  |  |  |
|-------------|-------------------|---------------------|---|--------------------|---|-------|----------|------------------|--|--|
| DESTINATION | +                 | In Range -          | + | Zero               | _ | +     | Infinity | _                |  |  |
| Result      | Log <sub>10</sub> | NAN                 | 2 | – inf <sup>3</sup> |   | + inf |          | NAN <sup>2</sup> |  |  |

#### NOTES:

1. If the source operand is a NAN, refer to 1.6.5 Not-A-Numbers for more information.

2. Sets the OPERR bit in the floating-point status register exception byte.

3. Sets the DZ bit in the floating-point status register exception byte.

### Floating-Point Status Register:

Condition Codes: Affected as described in 3.6.2 Conditional Testing.

Quotient Byte: Not affected.

Exception Byte: BSUN Cleared

SNAN Refer to **1.6.5 Not-A-Numbers**.

OPERR Set if the source operand is < 0; cleared

otherwise.

OVFL Cleared UNFL Cleared

DZ Set if the source is  $\pm$  0; cleared otherwise INEX2 Refer to inexact result in the appropriate

user's manual.

INEX1 If < fmt > is packed, refer to inexact result on

decimal input in the appropriate user's

manual; cleared otherwise.

Accrued Exception Byte: Affected as described in IEEE exception and trap compati-

bility in the appropriate user's manual.

FLOG<sub>10</sub>

# Log<sub>10</sub> (MC6888X, M68040FPSP)

FLOG<sub>10</sub>

#### **Instruction Format:**

| 15 | 14  | 13 | 12 | 11                | 10 | 9                 | 8        | 7 | 6 | 5    | 4 | 3 | 2       | 1       | 0     |     |  |
|----|-----|----|----|-------------------|----|-------------------|----------|---|---|------|---|---|---------|---------|-------|-----|--|
| 1  | 1   | 1  | 1  | COPROCESSOR       |    |                   | COPROCES | 0 |   | 0 0  | _ |   | EF      | FECTIVE | ADDRE | ESS |  |
| '  | '   | '  | '  |                   | ID |                   |          |   |   | MODE |   | F | REGISTE | R       |       |     |  |
| 0  | R/M | 0  |    | SOURCE<br>PECIFIE |    | DESTINA<br>REGIST |          |   | 0 | 0    | 1 | 0 | 1       | 0       | 1     |     |  |

#### **Instruction Fields:**

Coprocessor ID field—Specifies which coprocessor in the system is to execute this instruction. Motorola assemblers default to ID = 1 for the floating-point coprocessor.

Effective Address field—Determines the addressing mode for external operands.

If R/M = 0, this field is unused and should be all zeros.

If R/M = 1, this field is encoded with an M68000 family addressing mode as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn*                     | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| – (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | 111  | 100      |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |
| ([bd,PC,Xn],od)         | 111  | 011      |
| ([bd,PC],Xn,od)         | 111  | 011      |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

FLOG<sub>10</sub>

# Log<sub>10</sub> (MC6888X, M68040FPSP)

FLOG<sub>10</sub>

R/M field—Specifies the source operand address mode.

- 0 The operation is register to register.
- 1 The operation is < ea > to register.

Source Specifier field—Specifies the source register or data format.

If R/M = 0, specifies the source floating-point data register.

If R/M = 1, specifies the source data format:

- 000 Long-Word Integer (L)
- 001 Single-Precision Real (S)
- 010 Extended-Precision Real (X)
- 011 Packed-Decimal Real (P)
- 100 Word Integer (W)
- 101 Double-Precision Real (D)
- 110 Byte Integer (B)

FLOG2

# Log<sub>2</sub> (MC6888X, M68040FPSP)

FLOG2

**Operation:**  $Log_2$  of Source  $\rightarrow$  FPn

**Assembler** FLOG2. < fmt > < ea > ,FPn

**Syntax:** FLOG2.X FPm,FPn

FLOG2.X FPn

**Attributes:** Format = (Byte, Word, Long, Single, Double, Extended, Packed)

**Description:** Converts the source operand to extended precision (if necessary) and calculates the logarithm of that number using base two arithmetic. Stores the result in the destination floating- point data register. This function is not defined for input values less than zero.

### **Operation Table:**

|             |                  | SOURCE <sup>1</sup> |   |                    |       |                  |  |  |  |  |
|-------------|------------------|---------------------|---|--------------------|-------|------------------|--|--|--|--|
| DESTINATION | +                | In Range -          | + | Zero –             | +     | Infinity –       |  |  |  |  |
| Result      | Log <sub>2</sub> | NAN <sup>2</sup>    |   | – inf <sup>3</sup> | + inf | NAN <sup>2</sup> |  |  |  |  |

#### NOTES:

1. If the source operand is a NAN, refer to 1.6.5 Not-A-Numbers for more information.

2. Sets the OPERR bit in the floating-point status register exception byte.

3. Sets the DZ bit in the floating-point status register exception byte.

### Floating-Point Status Register:

Condition Codes: Affected as described in **3.6.2 Conditional Testing**.

Quotient Byte: Not affected.

Exception Byte: BSUN Cleared

SNAN Refer to **1.6.5 Not-A-Numbers**.

OPERR Set if the source is < 0; cleared otherwise

OVFL Cleared UNFL Cleared

DZ Set if the source is  $\pm$  0; cleared otherwise INEX2 Refer to inexact result in the appropriate

user's manual.

INEX1 If < fmt > is packed, refer to inexact result on

decimal input in the appropriate user's

manual; cleared otherwise.

Accrued Exception Byte: Affected as described in IEEE exception and trap compati-

bility in the appropriate user's manual.

FLOG2

# Log<sub>2</sub> (MC6888X, M68040FPSP)

FLOG2

#### **Instruction Format:**

| 15 | 14  | 13 | 12 | 11                | 10    | 9   | 8                  | 7     | 6 | 5             | 4  | 3       | 2     | 1  | 0 |
|----|-----|----|----|-------------------|-------|-----|--------------------|-------|---|---------------|----|---------|-------|----|---|
| 1  | 1   | 1  | 1  | COF               | ROCES | SOR | 0                  | 0     | _ |               | EF | FECTIVE | ADDRE | SS |   |
| '  | '   | '  | '  |                   | ID    |     | 0                  | 0   0 | 0 | MODE REGISTER |    |         |       | R  |   |
| 0  | R/M | 0  |    | SOURCE<br>PECIFIE |       |     | STINATI<br>REGISTE |       | 0 | 0             | 1  | 0       | 1     | 1  | 0 |

#### **Instruction Fields:**

Coprocessor ID field—Specifies which coprocessor in the system is to execute this instruction. Motorola assemblers default to ID = 1 for the floating-point coprocessor.

Effective Address field—Determines the addressing mode for external operands.

If R/M = 0, this field is unused and should be all zeros.

If R/M = 1, this field is encoded with an M68000 family addressing mode as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn*                     | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| – (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | 111  | 100      |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |
| ([bd,PC,Xn],od)         | 111  | 011      |
| ([bd,PC],Xn,od)         | 111  | 011      |
|                         |      |          |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

FLOG2

# Log<sub>2</sub> (MC6888X, M68040FPSP)

FLOG2

R/M field—Specifies the source operand address mode.

- 0 The operation is register to register.
- 1 The operation is < ea > to register.

Source Specifier field—Specifies the source register or data format.

If R/M = 0, specifies the source floating-point data register.

If R/M = 1, specifies the source data format:

000 — Long-Word Integer (L)

001 — Single-Precision Real (S)

010 — Extended-Precision Real (X)

011 — Packed-Decimal Real (P)

100 — Word Integer (W)

101 — Double-Precision Real (D)

110 — Byte Integer (B)

Destination Register field—Specifies the destination floating- point data register. If R/ M = 0 and the source and destination fields are equal, then the input operand is taken from the specified floating-point data register, and the result is written into the same register. If the single register syntax is used, Motorola assemblers set the source and destination fields to the same value.

FLOGN Log<sub>e</sub> FLOGN (MC6888X, M68040FPSP)

**Operation:**  $Log_e$  of  $Source \rightarrow FPn$ 

**Assembler** FLOGN. < fmt > < ea > ,FPn

**Syntax:** FLOGN.X FPm,FPn

FLOGN.X FPn

**Attributes:** Format = (Byte, Word, Long, Single, Double, Extended, Packed)

**Description:** Converts the source operand to extended precision (if necessary) and calculates the natural logarithm of that number. Stores the result in the destination floating-point data register. This function is not defined for input values less than zero.

### **Operation Table:**

|             |       | SOURCE <sup>1</sup> |                  |   |                    |   |       |          |                  |  |
|-------------|-------|---------------------|------------------|---|--------------------|---|-------|----------|------------------|--|
| DESTINATION | +     | In Range            | _                | + | Zero               | - | +     | Infinity | -                |  |
| Result      | In(x) |                     | NAN <sup>2</sup> |   | – inf <sup>3</sup> |   | + inf |          | NAN <sup>2</sup> |  |

#### NOTES:

1. If the source operand is a NAN, refer to 1.6.5 Not-A-Numbers for more information.

2. Sets the OPERR bit in the floating-point status register exception byte.

3. Sets the DZ bit in the floating-point status register exception byte.

### Floating-Point Status Register:

Condition Codes: Affected as described in **3.6.2 Conditional Testing.** 

Quotient Byte: Not affected.

Exception Byte: BSUN Cleared

SNAN Refer to **1.6.5 Not-A-Numbers**.

OPERR Set if the source operand is < 0; cleared

otherwise.

OVFL Cleared UNFL Cleared

DZ Set if the source is  $\pm$  0; cleared otherwise INEX2 Refer to inexact result in the appropriate

user's manual.

INEX1 If < fmt > is packed, refer to inexact result on

decimal input in the appropriate user's

manual: cleared otherwise.

Accrued Exception Byte: Affected as described in IEEE exception and trap compati-

bility in the appropriate user's manual.

# **FLOGN**

# Log<sub>e</sub> (MC6888X, M68040FPSP)

# **FLOGN**

#### **Instruction Format:**

| 15 | 14  | 13 | 12 | 11                | 10    | 9   | 8                  | 7   | 6     | 5             | 4 | 3  | 2       | 1     | 0   |  |
|----|-----|----|----|-------------------|-------|-----|--------------------|-----|-------|---------------|---|----|---------|-------|-----|--|
| 1  | 1   | 1  | 1  | COP               | ROCES | SOR | 0                  | 0 0 | ,   , | _             |   | EF | FECTIVE | ADDRE | ESS |  |
| '  | '   | '  | '  |                   | ID    |     | "                  |     | ١     | MODE REGISTER |   |    |         |       | R   |  |
| 0  | R/M | 0  |    | SOURCE<br>PECIFIE |       |     | STINATI<br>REGISTE |     | 0     | 0             | 1 | 0  | 1       | 0     | 0   |  |

#### **Instruction Fields:**

Coprocessor ID field—Specifies which coprocessor in the system is to execute this instruction. Motorola assemblers default to ID = 1 for the floating-point coprocessor.

Effective Address field—Determines the addressing mode for external operands.

If R/M = 0, this field is unused and should be all zeros.

If R/M = 1, this field is encoded with an M68000 family addressing mode as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn*                     | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| – (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | 111  | 100      |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |
| ([bd,PC,Xn],od)         | 111  | 011      |
| ([bd,PC],Xn,od)         | 111  | 011      |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

## **FLOGN**

### Log<sub>e</sub> (MC6888X, M68040FPSP)

**FLOGN** 

R/M field—Specifies the source operand address mode.

- 0 The operation is register to register.
- 1 The operation is < ea > to register.

Source Specifier field—Specifies the source register or data format.

If R/M = 0, specifies the source floating-point data register.

If R/M = 1, specifies the source data format:

- 000 Long-Word Integer (L)
- 001 Single-Precision Real (S)
- 010 Extended-Precision Real (X)
- 011 Packed-Decimal Real (P)
- 100 Word Integer (W)
- 101 Double-Precision Real (D)
- 110 Byte Integer (B)

Destination Register field—Specifies the destination floating- point data register. If R/ M = 0 and the source and destination fields are equal, then the input operand is taken from the specified floating-point data register, and the result is written into the same register. If the single register syntax is used, Motorola assemblers set the source and destination fields to the same value.

FLOGNP1

Log<sub>e</sub> (x + 1) (MC6888X, M68040FPSP) FLOGNP1

**Operation:** Log<sub>e</sub> of (Source + 1)  $\rightarrow$  FPn

**Assembler** FLOGNP1. < fmt > < ea > ,FPn

**Syntax:** FLOGNP1.X FPm,FPn

FLOGNP1.X FPn

**Attributes:** Format = (Byte, Word, Long, Single, Double, Extended, Packed)

**Description:** Converts the source operand to extended precision (if necessary), adds one to that value, and calculates the natural logarithm of that intermediate result. Stores the result in the destination floating-point data register. This function is not defined for input values less than – 1.

### **Operation Table:**

|             |           | SOURCE <sup>1</sup> |             |      |       |       |                    |  |  |  |
|-------------|-----------|---------------------|-------------|------|-------|-------|--------------------|--|--|--|
| DESTINATION | +         | In Range            | - +         | Zero | _     | +     | Infinity –         |  |  |  |
| Result      | In(x + 1) | In(x + 1            | $)^2 + 0.0$ |      | - 0.0 | + inf | NAN <sup>2</sup> 3 |  |  |  |

#### NOTES:

- 1. If the source operand is a NAN, refer to 1.6.5 Not-A-Numbers for more information.
- 2. If the source is 1, sets the DZ bit in the floating-point status register exception byte and returns a NAN. If the source is < 1, sets the OPERR bit in the floating-point status register exception byte and returns a NAN.
- 3. Sets the OPERR bit in the floating-point status register exception byte.

#### Floating-Point Status Register:

Condition Codes: Affected as described in **3.6.2 Conditional Testing.** 

Quotient Byte: Not affected.

FLOGNP1

 $Log_e(x + 1)$ (MC6888X, M68040FPSP) FLOGNP1

Exception Byte: BSUN Cleared

SNAN Refer to **1.6.5 Not-A-Numbers**.

OPERR Set if the source operand is < -1; cleared

otherwise.

OVFL Cleared

UNFL Refer to underflow in the appropriate user's

manual.

DZ Set if the source operand is -1; cleared

otherwise

INEX2 Refer to inexact result in the appropriate

user's manual.

INEX1 If < fmt > is packed, refer to inexact result on

decimal input in the appropriate user's

manual; cleared otherwise.

Accrued Exception Byte: Affected as described in IEEE exception and trap compati-

bility in the appropriate user's manual.

#### **Instruction Format:**

| 15 | 14  | 13 | 12 | 11     | 10    | 9                    | 8 | 7     | 6             | 5   | 4 | 3   | 2       | 1     | 0  |  |
|----|-----|----|----|--------|-------|----------------------|---|-------|---------------|-----|---|-----|---------|-------|----|--|
| 1  | 1   | 1  | 1  | COF    | ROCES | SOR                  | R |       | 0             | 0 0 |   | EFI | FECTIVE | ADDRE | SS |  |
| 1  | '   | '  | '  |        | ID    |                      | " | 0   0 | MODE REGISTER |     |   |     |         | R     |    |  |
| 0  | R/M | 0  |    | SOURCE |       | DESTINATI<br>REGISTE |   |       | 0             | 0   | 0 | 0   | 1       | 1     | 0  |  |

#### **Instruction Fields:**

Coprocessor ID field—Specifies which coprocessor in the system is to execute this instruction. Motorola assemblers default to ID = 1 for the floating-point coprocessor.

### FLOGNP1

### Log<sub>e</sub> (x + 1) (MC6888X, M68040FPSP)

## FLOGNP1

Effective Address field—Determines the addressing mode for external operands.

If R/M = 0, this field is unused and should be all zeros.

If R/M = 1, this field is encoded with an M68000 family addressing mode as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn*                     | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| – (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | 111  | 100      |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |
| ([bd,PC,Xn],od)         | 111  | 011      |
| ([bd,PC],Xn,od)         | 111  | 011      |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

R/M field—Specifies the source operand address mode.

0 — The operation is register to register.

1 — The operation is < ea > to register.

Source Specifier field—Specifies the source register or data format.

If R/M = 0, specifies the source floating-point data register.

If R/M = 1, specifies the source data format:

000 — Long-Word Integer (L)

001 — Single-Precision Real (S)

010 — Extended-Precision Real (X)

011 — Packed-Decimal Real (P)

100 — Word Integer (W)

101 — Double-Precision Real (D)

110 — Byte Integer (B)

Destination Register field—Specifies the destination floating- point data register. If R/ M = 0 and the source and destination fields are equal, then the input operand is taken from the specified floating-point data register, and the result is written into the same register. If the single register syntax is used, Motorola assemblers set the source and destination fields to the same value.

FMOD

Modulo Remainder
(MC6888X, M68040FPSP)

FMOD

**Operation:** Modulo Remainder of (FPn  $\div$  Source)  $\rightarrow$  FPn

**Assembler** FMOD. < fmt > < ea > ,FPn

**Syntax:** FMOD.X FPm,FPn

**Attributes:** Format = (Byte, Word, Long, Single, Double, Extended, Packed)

**Description:** Converts the source operand to extended precision (if necessary) and calculates the modulo remainder of the number in the destination floating-point data register, using the source operand as the modulus. Stores the result in the destination floating-point data register and stores the sign and seven least significant bits of the quotient in the floating-point status register quotient byte (the quotient is the result of FPn ÷ Source). The modulo remainder function is defined as:

where  $N = INT(FPn \div Source)$  in the round-to-zero mode.

The FMOD function is not defined for a source operand equal to zero or for a destination operand equal to infinity. Note that this function is not the same as the FREM instruction, which uses the round-to-nearest mode and thus returns the remainder that is required by the IEEE *Specification for Binary Floating-Point Arithmetic*.

### **Operation Table:**

|             |   |                  | SOURCE <sup>1</sup> |                  |  |  |  |  |  |  |  |
|-------------|---|------------------|---------------------|------------------|--|--|--|--|--|--|--|
| DESTINATION |   | + In Range -     | + Zero# -           | + Infinity -     |  |  |  |  |  |  |  |
| In Range    | + | Modulo Remainder | NAN <sup>2</sup>    | FPn <sup>3</sup> |  |  |  |  |  |  |  |
| Zero        | + | + 0.0<br>- 0.0   | NAN <sup>2</sup>    | + 0.0<br>- 0.0   |  |  |  |  |  |  |  |
| Infinity    | + | NAN <sup>2</sup> | NAN <sup>2</sup>    | NAN <sup>2</sup> |  |  |  |  |  |  |  |

#### NOTES:

- 1. If the source operand is a NAN, refer to 1.6.5 Not-A-Numbers for more information.
- 2. Sets the OPERR bit in the floating-point status register exception byte.
- 3. Returns the value of FPn before the operation. However, the result is processed by the normal instruction termination procedure to round it as required. Thus, an overflow and/or inexact result may occur if the rounding precision has been changed to a smaller size since the FPn value was loaded

## **FMOD**

# Modulo Remainder (MC6888X, M68040FPSP)

## **FMOD**

### Floating-Point Status Register:

Condition Codes: Affected as described in **3.6.2 Conditional Testing**.

Quotient Byte: Loaded with the sign and least significant seven bits of the

quotient (FPn ÷ Source). The sign of the quotient is the exclusive-OR of the sign bits of the source and destination

operands.

Exception Byte: BSUN Cleared

SNAN Refer to **1.6.5 Not-A-Numbers**.

OPERR Set if the source is zero or the destination is

infinity; cleared otherwise.

OVFL Cleared

UNFL Refer to underflow in the appropriate user's

manual.

DZ Cleared

INEX2 Refer to inexact result in the appropriate

user's manual.

INEX1 If < fmt > is packed, in the appropriate user's

manual for inexact result on decimal input;

cleared otherwise.

Accrued Exception Byte: Affected as described in IEEE exception and trap compati-

bility in the appropriate user's manual.

#### **Instruction Format:**

| 15 | 14  | 13 | 12 | 11  | 10          | 9                 | 8 | 7 | 6 | 5 | 4    | 3       | 2       | 1       | 0 |
|----|-----|----|----|-----|-------------|-------------------|---|---|---|---|------|---------|---------|---------|---|
| 1  | 1   | 1  | 1  | COF | COPROCESSOR |                   |   |   |   |   | EF   | FECTIVE | E ADDRE | ESS     |   |
| '  | '   | '  | '  |     | ID          | 0                 |   |   | " |   | MODE |         | R       | REGISTE | R |
| 0  | R/M | 0  | 1  |     |             | STINATI<br>EGISTE | - | 0 | 1 | 0 | 1    | 1       | 0       | 1       |   |

#### Instruction Fields:

Coprocessor ID field—Specifies which coprocessor in the system is to execute this instruction. Motorola assemblers default to ID = 1 for the floating-point coprocessor.

**FMOD** 

# Modulo Remainder (MC6888X, M68040FPSP)

**FMOD** 

Effective Address field—Determines the addressing mode for external operands.

If R/M = 0, this field is unused and should be all zeros.

If R/M = 1, this field is encoded with an M68000 family addressing mode as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn                      | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| – (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |  |  |  |
|-------------------------|------|----------|--|--|--|
| (xxx).W                 | 111  | 000      |  |  |  |
| (xxx).L                 | 111  | 001      |  |  |  |
| # < data >              | 111  | 100      |  |  |  |
|                         |      |          |  |  |  |
|                         |      |          |  |  |  |
| (d <sub>16</sub> ,PC)   | 111  | 010      |  |  |  |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |  |  |  |
| (bd,PC,Xn)              | 111  | 011      |  |  |  |
| ([bd,PC,Xn],od)         | 111  | 011      |  |  |  |
| ([bd,PC],Xn,od)         | 111  | 011      |  |  |  |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

R/M field—Specifies the source operand address mode.

- 0 The operation is register to register.
- 1 The operation is < ea > to register.

Source Specifier field—Specifies the source register or data format.

If R/M = 0, specifies the source floating-point data register.

If R/M = 1, specifies the source data format:

- 000 Long-Word Integer (L)
- 001 Single-Precision Real (S)
- 010 Extended-Precision Real (X)
- 011 Packed-Decimal Real (P)
- 100 Word Integer (W)
- 101 Double-Precision Real (D)
- 110 Byte Integer (B)

Destination Register field—Specifies the destination floating- point data register.

# FMOVE Move Floating-Point Data Register (MC6888X, MC68040)

**FMOVE** 

**Operation:** Source → Destination

**Assembler** FMOVE. < fmt > < ea > ,FPn **Syntax:** FMOVE. < fmt > FPm, < ea >

FMOVE.P FPm, < ea > {Dn} FMOVE.P FPm, < ea > {k} \*FrMOVE. < fmt > < ea > ,FPn

where r is rounding precision, S or D

\*Supported by MC68040 only

**Attributes:** Format = (Byte, Word, Long, Single, Double, Extended, Packed)

**Description:** Moves the contents of the source operand to the destination operand. Although the primary function of this instruction is data movement, it is also considered an arithmetic instruction since conversions from the source operand format to the destination operand format are performed implicitly during the move operation. Also, the source operand is rounded according to the selected rounding precision and mode.

Unlike the MOVE instruction, the FMOVE instruction does not support a memory-to-memory format. For such transfers, it is much faster to utilize the MOVE instruction to transfer the floating- point data than to use the FMOVE instruction. The FMOVE instruction only supports memory-to-register, register-to- register, and register-to-memory operations (in this context, memory may refer to an integer data register if the data format is byte, word, long, or single). The memory-to-register and register- to-register operation uses a command word encoding distinctly different from that used by the register-to-memory operation; these two operation classes are described separately.

Memory-to-Register and Register-to-Register Operation: Converts the source operand to an extended-precision floating-point number (if necessary) and stores it in the destination floating-point data register. MOVE will round the result to the precision selected in the floating-point control register. FSMOVE and FDMOVE will round the result to single or double precision, respectively, regardless of the rounding precision selected in the floating-point control register. Depending on the source data format and the rounding precision, some operations may produce an inexact result. In the following table, combinations that can produce an inexact result are marked with a dot (·), but all other combinations produce an exact result.

# Move Floating-Point Data Register (MC6888X, MC68040)

# **FMOVE**

| Rounding  |   | Source Format |   |   |   |   |   |  |  |  |  |  |  |
|-----------|---|---------------|---|---|---|---|---|--|--|--|--|--|--|
| Precision | В | W             | L | S | D | Х | Р |  |  |  |  |  |  |
| Single    |   |               | • |   | • | • | • |  |  |  |  |  |  |
| Double    |   |               |   |   |   | • | • |  |  |  |  |  |  |
| Extended  |   |               |   |   |   |   | • |  |  |  |  |  |  |

### Floating-Point Status Register ( < ea > to Register):

Condition Codes: Affected as described in **3.6.2 Conditional Testing.** 

Quotient Byte: Not affected.

Exception Byte: BSUN Cleared

SNAN Refer to **1.6.5 Not-A-Numbers.** 

OPERR Cleared OVFL Cleared

UNFL Refer to exception processing in the

appropriate user's manual if the source is an extended-precision denormalized number;

cleared otherwise.

DZ Cleared

INEX2 Refer to exception processing in the

appropriate user's manual if < fmt > is L,D, or

X; cleared otherwise.

INEX1 Refer to exception processing in the

appropriate user's manual if < fmt > is P;

cleared otherwise.

Accrued Exception Byte: Affected as described in exception processing in the appro-

priate user's manual.

# Move Floating-Point Data Register (MC6888X, MC68040)

# **FMOVE**

#### **Instruction Format:**

#### < EA > TO REGISTER

| 15 | 14  | 13 | 12 | 11  | 10                | 9 | 8                 | 7 | 6 | 5 | 4    | 3      | 2     | 1       | 0  |
|----|-----|----|----|-----|-------------------|---|-------------------|---|---|---|------|--------|-------|---------|----|
| 1  | 1   | 1  | 1  | COF | COPROCESSOR       |   | R 0               |   | 0 |   | EFF  | ECTIVE | ADDRE | ESS     |    |
| '  | '   | '  | '  |     | ID                |   | "                 | " |   |   | MODE |        | F     | REGISTE | :R |
| 0  | R/M | 0  |    |     | OURCE<br>PECIFIER |   | STINATI<br>EGISTE | - |   |   | (    | PMODI  | E     |         |    |

#### **Instruction Fields:**

Effective Address field—Determines the addressing mode for external operands.

If R/M = 0, this field is unused and should be all zeros.

If R/M = 1, specifies the location of the source operand. Only data addressing modes can be used as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn*                     | 000  | reg. number:Dn |
| An                      |      | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| – (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | 111  | 100      |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |
| ([bd,PC,Xn],od)         | 111  | 011      |
| ([bd,PC],Xn,od)         | 111  | 011      |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

R/M field—Specifies the source operand address mode.

- 0 The operation is register to register.
- 1 The operation is < ea > to register.

# Move Floating-Point Data Register (MC6888X, MC68040)

**FMOVE** 

Source Specifier field—Specifies the source register or data format.

If R/M = 0, specifies the source floating-point data register.

If R/M = 1, specifies the source data format:

000 — Long-Word Integer (L)

001 — Single-Precision Real (S)

010 — Extended-Precision Real (X)

011 — Packed-Decimal Real (P)\*

100 — Word Integer (W)

101 — Double-Precision Real (D)

110 — Byte Integer (B)

\*This encoding in the MC68040 will cause an unimplemented data type exception to allow emulation in software.

Destination Register field—Specifies the destination floating- point data register.

Opmode field—Specifies the instruction and rounding precision.

0000000 FMOVE Rounding precision specified by the floating-point control register.
 1000000 FSMOVE Single-precision rounding specified.
 1000100 FDMOVE Double-precision rounding specified.

**Register-to-Memory Operation:** Rounds the source operand to the size of the specified destination format and stores it at the destination effective address. If the format of the destination is packed decimal, a third operand is required to specify the format of the resultant string. This operand, called the k-factor, is a 7-bit signed integer (twos complement) and may be specified as an immediate value or in an integer data register. If a data register contains the k-factor, only the least significant seven bits are used, and the rest of the register is ignored.

< fmt > is S, D, or X

< fmt > is P

# Move Floating-Point Data Register (MC6888X, MC68040)

**FMOVE** 

### Floating-Point Status Register (Register-to-Memory):

Condition Codes: Not affected.

Quotient Byte: Not affected.

Exception Byte: BSUN Cleared

< fmt > is B, W, or L SNAN Refer to 1.6.5 Not-A-Numbers.

OPERR Set if the source operand is infinity or if the

destination size is exceeded after conversion

and rounding; cleared otherwise.

OVFL Cleared UNFL Cleared DZ Cleared

INEX2 Refer to exception processing in the

appropriate user's manual.

INEX1 Cleared BSUN Cleared

SNAN Refer to 1.6.5 Not-A-Numbers

OVFL Refer to exception processing in the

appropriate user's manual.

UNFL Refer to exception processing in the

appropriate user's manual.

DZ Cleared

INEX2 Refer to exception processing in the

appropriate user's manual.

INEX1 Cleared BSUN Cleared

SNAN Refer to **1.6.5 Not-A-Numbers**.

OPERR Set if the k-factor > + 17 or the magnitude of

the decimal exponent exceeds three digits;

cleared otherwise.

OVFL Cleared UNFL Cleared DZ Cleared

INEX2 Refer to exception processing in the

appropriate user's manual.

INEX1 Cleared

Accrued Exception Byte: Affected as described in exception processing in the appro-

priate user's manual.

# Move Floating-Point Data Register (MC6888X, MC68040)

# **FMOVE**

#### **Instruction Format:**

#### REGISTER—TO-MEMORY

| 15 | 14 | 13 | 12  | 11      | 10  | 9 | 8       | 7 | 6             | 5        | 4    | 3      | 2     | 1       | 0 |
|----|----|----|-----|---------|-----|---|---------|---|---------------|----------|------|--------|-------|---------|---|
| 1  | 1  | 1  | COF | ROCES   | SOR | 1 | 0       | 0 | 0             |          | EFI  | ECTIVE | ADDRE | ESS     |   |
|    |    | '  |     | ID      |     |   |         |   | "             |          | MODE |        | F     | REGISTE | R |
| 0  | 1  | 1  | DE: | STINATI | ION | , | SOURCE  |   |               | K-FACTOR |      |        |       |         |   |
| "  | '  | '  | F   | FORMAT  | Γ   | R | REGISTE | R | (IF REQUIRED) |          |      |        |       |         |   |

#### **Instruction Fields:**

Effective Address field—Specifies the destination location. Only data alterable addressing modes can be used as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn*                     | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| - (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | _    | _        |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | _    |          |
| (d <sub>8</sub> ,PC,Xn) | _    |          |
| (bd,PC,Xn)              | _    | _        |
| ([bd,PC,Xn],od)         | _    | _        |
| ([bd,PC],Xn,od)         | _    | _        |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

Destination Format field—Specifies the data format of the destination operand:

- 000 Long-Word Integer (L)
- 001 Single-Precision Real (S)
- 010 Extended-Precision Real (X)
- 011 Packed-Decimal Real with Static k-Factor (P{#k})\*
- 100 Word Integer (W)
- 101 Double-Precision Real (D)
- 110 Byte Integer (B)
- 111 Packed-Decimal Real with Dynamic k-Factor (P{Dn})\*

<sup>\*</sup>This encoding will cause an unimplemented data type exception in the MC68040 to allow emulation in software.

# Move Floating-Point Data Register (MC6888X, MC68040)

**FMOVE** 

Source Register field—Specifies the source floating-point data register.

- k-Factor field—If the destination format is packed decimal, used to specify the format of the decimal string. For any other destination format, this field should be set to all zeros. For a static k-factor, this field is encoded with a twos-complement integer where the value defines the format as follows:
  - 64 to 0—Indicates the number of significant digits to the right of the decimal point (FORTRAN "F" format).
  - + 1 to + 17—Indicates the number of significant digits in the mantissa (FORTRAN "E" format).
  - + 18 to + 63—Sets the OPERR bit in the floating-point status register exception byte and treated as + 17.

The format of this field for a dynamic k-factor is:

rrr0000

where "rrr" is the number of the main processor data register that contains the k-factor value.

The following table gives several examples of how the k-factor value affects the format of the decimal string that is produced by the floating-point coprocessor. The format of the string that is generated is independent of the source of the k-factor (static or dynamic).

| k- Factor  | Source Operand Value | Destination String |
|------------|----------------------|--------------------|
| <b>-</b> 5 | + 12345.678765       | + 1.234567877E + 4 |
| - 3        | + 12345.678765       | + 1.2345679E + 4   |
| - 1        | + 12345.678765       | + 1.23457E + 4     |
| 0          | + 12345.678765       | + 1.2346E + 4      |
| + 1        | + 12345.678765       | + 1.E + 4          |
| + 3        | + 12345.678765       | + 1.23E + 4        |
| + 5        | + 12345.678765       | + 1.2346E + 4      |

Move Floating-Point System Control Register (MC6888X, MC68040) **FMOVE** 

**Operation:** Source → Destination

Assembler FMOVE.L < ea > ,FPCR Syntax: FMOVE.L FPCR, < ea >

**Attributes:** Size = (Long)

**Description:** Moves the contents of a floating-point system control register (floating-point control register, floating-point status register, or floating-point instruction address register) to or from an effective address. A 32-bit transfer is always performed, even though the system control register may not have 32 implemented bits. Unimplemented bits of a control register are read as zeros and are ignored during writes (must be zero for compatibility with future devices). For the MC68881, this instruction does not cause pending exceptions (other than protocol violations) to be reported. Furthermore, a write to the floating-point control register exception enable byte or the floating-point status register exception status byte cannot generate a new exception, regardless of the value written.

**Floating-Point Status Register:** Changed only if the destination is the floating-point status register, in which case all bits are modified to reflect the value of the source operand.

#### **Instruction Format:**

| 15 | 14 | 13 | 12 | 11               | 10              | 9   | 8 | 7 | 6 | 5 | 4    | 3 | 2 | 1      | 0 |  |  |  |    |         |       |    |  |
|----|----|----|----|------------------|-----------------|-----|---|---|---|---|------|---|---|--------|---|--|--|--|----|---------|-------|----|--|
| 1  | 1  | 1  | 1  | COPROCESSOR      |                 | SOR | ٦ |   |   |   |      |   |   |        |   |  |  |  | EF | FECTIVE | ADDRE | SS |  |
| '  | '  | ·  | '  |                  | ID              |     | " |   | " |   | MODE |   | R | EGISTE | R |  |  |  |    |         |       |    |  |
| 1  | 0  | dr |    | EGISTE<br>SELECT | GISTER<br>ELECT |     | 0 | 0 | 0 | 0 | 0    | 0 | 0 | 0      | 0 |  |  |  |    |         |       |    |  |

### Move Floating-Point System Control Register (MC6888X, MC68040)

# **FMOVE**

#### **Instruction Fields:**

Effective Address field—(Memory-to-Register) All addressing modes can be used as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn                      | 000  | reg. number:Dn |
| An*                     | 001  | reg. number:An |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| – (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | 111  | 100      |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |
| ([bd,PC,Xn],od)         | 111  | 011      |
| ([bd,PC],Xn,od)         | 111  | 011      |

<sup>\*</sup>Only if the source register is the floating-point instruction address register.

Effective Address field—(Register-to-Memory) Only alterable addressing modes can be used as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn                      | 000  | reg. number:Dn |
| An*                     | 001  | reg. number:An |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| - (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | _    | _        |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | _    |          |
| (d <sub>8</sub> ,PC,Xn) | _    |          |
| (bd,PC,Xn)              | _    | _        |
| ([bd,PC,Xn],od)         | _    | _        |
| ([bd,PC],Xn,od)         | _    | _        |
|                         |      |          |

<sup>\*</sup>Only if the source register is the floating-point instruction address register.

### Move Floating-Point System Control Register (MC6888X, MC68040)

**FMOVE** 

dr field—Specifies the direction of the data transfer.

- 0 From < ea > to the specified system control register.
- 1 From the specified system control register to < ea > .

Register Select field—Specifies the system control register to be moved:

- 100 Floating-Point Control Register
- 010 Floating-Point Status Register
- 001 Floating-Point Instruction Address Register

**FMOVECR** 

Move Constant ROM (MC6888X, M68040FPSP)

**FMOVECR** 

**Operation:** ROM Constant  $\rightarrow$  FPn

Assembler

**Syntax:** FMOVECR.X # < ccc > ,FPn

**Attributes:** Format = (Extended)

**Description:** Fetches an extended-precision constant from the floating-point coprocessor on-chip ROM, rounds the mantissa to the precision specified in the floating-point control register mode control byte, and stores it in the destination floating-point data register. The constant is specified by a predefined offset into the constant ROM. The values of the constants contained in the ROM are shown in the offset table at the end of this description.

### Floating-Point Status Register:

Condition Codes: Affected as described in **3.6.2 Conditional Testing.** 

Quotient Byte: Not affected.

Exception Byte: BSUN Cleared

SNAN Cleared
OPERR Cleared
OVFL Cleared
UNFL Cleared
DZ Cleared

INEX2 Refer to inexact result in the appropriate

user's manual.

INEX1 Cleared

Accrued Exception Byte: Affected as described in IEEE exception and trap compati-

bility in the appropriate user's manual.

#### **Instruction Format:**

| 15 | 14 | 13 | 12 | 11  | 10          | 9   | 8                       | 7 | 6 | 5 | 4  | 3      | 2   | 1 | 0 |
|----|----|----|----|-----|-------------|-----|-------------------------|---|---|---|----|--------|-----|---|---|
| 1  | 1  | 1  | 1  | COF | ROCES<br>ID | SOR | 0                       | 0 | 0 | 0 | 0  | 0      | 0   | 0 | 0 |
| 0  | 1  | 0  | 1  | 1   | 1           | 1   | DESTINATION<br>REGISTER |   |   |   | RC | M OFFS | SET |   |   |

**FMOVECR** 

Move Constant ROM (MC6888X, M68040FPSP)

**FMOVECR** 

#### Instruction Fields:

Coprocessor ID field—Specifies which coprocessor in the system is to execute this instruction. Motorola assemblers default to ID = 1 for the floating-point coprocessor.

Destination Register field—Specifies the destination floating- point data register.

ROM Offset field—Specifies the offset into the floating-point coprocessor on-chip constant ROM where the desired constant is located. The offsets for the available constants are as follows:

| Offset | Constant              |
|--------|-----------------------|
| \$00   | $\pi$                 |
| \$0B   | Log <sub>10</sub> (2) |
| \$0C   | е                     |
| \$0D   | Log <sub>2</sub> (e)  |
| \$0E   | Log <sub>10</sub> (e) |
| \$0F   | 0.0                   |
| \$30   | 1n(2)                 |
| \$31   | 1n(10)                |
| \$32   | 100                   |
| \$33   | 10 <sup>1</sup>       |
| \$34   | 10 <sup>2</sup>       |
| \$35   | 10 <sup>4</sup>       |
| \$36   | 10 <sup>8</sup>       |
| \$37   | 10 <sup>16</sup>      |
| \$38   | 10 <sup>32</sup>      |
| \$39   | 10 <sup>64</sup>      |
| \$3A   | 10 <sup>128</sup>     |
| \$3B   | 10 <sup>256</sup>     |
| \$3C   | 10 <sup>512</sup>     |
| \$3D   | 10 <sup>1024</sup>    |
| \$3E   | 10 <sup>2048</sup>    |
| \$3F   | 10 <sup>4096</sup>    |

The on-chip ROM contains other constants useful only to the on- chip microcode routines. The values contained at offsets other than those defined above are reserved for the use of Motorola and may be different on various mask sets of the floating-point coprocessor. These undefined values yield the value 0.0 in the M68040FPSP.

### Move Multiple Floating-Point Data Registers (MC6888X, MC68040)

**FMOVEM** 

**Operation:** Register List  $\rightarrow$  Destination

Source → Register List

Assembler FMOVEM.X < list > , < ea > Syntax: FMOVEM.X Dn, < ea >

FMOVEM.X < ea > , < list > FMOVEM.X < ea > , Dn

**Attributes:** Format = (Extended)

**Description:**Moves one or more extended-precision numbers to or from a list of floating-point data registers. No conversion or rounding is performed during this operation, and the floating-point status register is not affected by the instruction. For the MC68881, this instruction does not cause pending exceptions (other than protocol violations) to be reported. Furthermore, a write to the floating-point control register exception enable byte or the floating-point status register exception status byte connot generate a new exception, despite the value written.

Any combination of the eight floating-point data registers can be transferred, with the selected registers specified by a user- supplied mask. This mask is an 8-bit number, where each bit corresponds to one register; if a bit is set in the mask, that register is moved. The register select mask may be specified as a static value contained in the instruction or a dynamic value in the least significant eight bits of an integer data register (the remaining bits of the register are ignored).

FMOVEM allows three types of addressing modes: the control modes, the predecrement mode, or the postincrement mode. If the effective address is one of the control addressing modes, the registers are transferred between the processor and memory starting at the specified address and up through higher addresses. The order of the transfer is from FP0 – FP7.

### Move Multiple Floating-Point Data Registers (MC6888X, MC68040)

**FMOVEM** 

If the effective address is the predecrement mode, only a register- to-memory operation is allowed. The registers are stored starting at the address contained in the address register and down through lower addresses. Before each register is stored, the address register is decremented by 12 (the size of an extended-precision number in memory) and the floating-point data register is then stored at the resultant address. When the operation is complete, the address register points to the image of the last floating-point data register stored. The order of the transfer is from FP7 – FP0.

If the effective address is the postincrement mode, only a memory- to-register operation is allowed. The registers are loaded starting at the specified address and up through higher addresses. After each register is stored, the address register is incremented by 12 (the size of an extended-precision number in memory). When the operation is complete, the address register points to the byte immediately following the image of the last floating-point data register loaded. The order of the transfer is the same as for the control addressing modes: FP0 – FP7.

**Floating-Point Status Register:** Not Affected. Note that the FMOVEM instruction provides the only mechanism for moving a floating-point data item between the floating-point unit and memory without performing any data conversions or affecting the condition code and exception status bits.

#### **Instruction Format:**

| 15 | 14 | 13 | 12 | 11          | 10 | 9   | 8 | /             | 6 | 5 | 4    | 3      | 2     | 1      | 0 |
|----|----|----|----|-------------|----|-----|---|---------------|---|---|------|--------|-------|--------|---|
| 4  | 1  | 1  |    | COPROCESSOR |    | COF | _ | 0             | 0 |   | EFF  | ECTIVE | ADDRE | ESS    |   |
| '  | '  | '  | '  |             | ID |     | 0 | 0             | 0 |   | MODE |        | F     | EGISTE | R |
| 1  | 1  | dr | MC | DE          | 0  | 0   | 0 | REGISTER LIST |   |   |      |        |       |        |   |

### Move Multiple Floating-Point Data Registers (MC6888X, MC68040)

# **FMOVEM**

#### **Instruction Fields:**

Effective Address field—(Memory-to-Register) Only control addressing modes or the postincrement addressing mode can be used as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn                      | _    | _              |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| – (An)                  | _    | _              |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | _    |          |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |
| ([bd,PC,Xn],od)         | 111  | 011      |
| ([bd,PC],Xn,od)         | 111  | 011      |

Effective Address field—(Register-to-Memory) Only control alterable addressing modes or the predecrement addressing mode can be used as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn                      | _    | _              |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | _    | _              |
| – (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | -    | 1        |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | _    |          |
| (d <sub>8</sub> ,PC,Xn) | _    |          |
| (bd,PC,Xn)              | _    | _        |
| ([bd,PC,Xn],od)         | _    | _        |
| ([bd,PC],Xn,od)         | _    | _        |

### Move Multiple Floating-Point Data Registers (MC6888X, MC68040)

**FMOVEM** 

dr field—Specifies the direction of the transfer.

- 0 Move the listed registers from memory to the floating-point unit.
- 1 Move the listed registers from the floating-point unit to memory.

Mode field—Specifies the type of the register list and addressing mode.

- 00 Static register list, predecrement addressing mode.
- 01 Dynamic register list, predecrement addressing mode.
- 10 Static register list, postincrement or control addressing mode.
- 11 Dynamic register list, postincrement or control addressing mode.

### Register List field:

Static list—contains the register select mask. If a register is to be moved, the corresponding bit in the mask is set as shown below; otherwise it is clear.

Dynamic list—contains the integer data register number, rrr, as listed in the following table:

| List Type                      | Register List Format |     |     |     |     |     |     |     |  |  |  |
|--------------------------------|----------------------|-----|-----|-----|-----|-----|-----|-----|--|--|--|
| Static, - (An)                 | FP7                  | FP6 | FP5 | FP4 | FP3 | FP2 | FP1 | FP0 |  |  |  |
| Static, (An) + ,<br>or Control | FP0                  | FP1 | FP2 | FP3 | FP4 | FP5 | FP6 | FP7 |  |  |  |
| Dynamic                        | 0                    | r   | r   | r   | 0   | 0   | 0   | 0   |  |  |  |

The format of the dynamic list mask is the same as for the static list and is contained in the least significant eight bits of the specified main processor data register.

**Programming Note:** This instruction provides a very useful feature, dynamic register list specification, that can significantly enhance system performance. If the calling conventions used for procedure calls utilize the dynamic register list feature, the number of floating-point data registers saved and restored can be reduced.

To utilize the dynamic register specification feature of the FMOVEM instruction, both the calling and the called procedures must be written to communicate information about register usage. When one procedure calls another, a register mask must be passed to the called procedure to indicate which registers must not be altered upon return to the calling procedure. The called procedure then saves only those registers that are modified and are already in use. Several techniques can be used to utilize this mechanism, and an example follows.

### Move Multiple Floating-Point Data Registers (MC6888X, MC68040)

## **FMOVEM**

In this example, a convention is defined by which each called procedure is passed a word mask in D7 that identifies all floating-point registers in use by the calling procedure. Bits 15-8 identify the registers in the order FP0 – FP7, and bits 7-0 identify the registers in the order FP7 – FP0 (the two masks are required due to the different transfer order used by the predecrement and postincrement addressing modes). The code used by the calling procedure consists of simply moving the mask (which is generated at compile time) for the floating-point data registers currently in use into D7:

Calling procedure...

MOVE.W #ACTIVE,D7 Load the list of FP registers that are in use.

BSR PROC 2

The entry code for all other procedures computes two masks. The first mask identifies the registers in use by the calling procedure that are used by the called procedure (and therefore saved and restored by the called procedure). The second mask identifies the registers in use by the calling procedure that are used by the called procedure (and therefore not saved on entry). The appropriate registers are then stored along with the two masks:

### Called procedure...

| MOVE.W        | D7,D6        | Copy the list of active registers.    |
|---------------|--------------|---------------------------------------|
| AND.W         | #WILL_USE,D7 | Generate the list of doubly-used      |
|               | registers.   |                                       |
| <b>FMOVEM</b> | D7, - (A7)   | Save those registers.                 |
| MOVE.W        | D7, - (A7)   | Save the register list.               |
| EOR.W         | D7,D6        | Generate the list of not saved active |
|               | registers.   |                                       |
| MOVE.W        | D6, -(A7)    | Save it for later use.                |

If the second procedure calls a third procedure, a register mask is passed to the third procedure that indicates which registers must not be altered by the third procedure. This mask identifies any registers in the list from the first procedure that were not saved by the second procedure, plus any registers used by the second procedure that must not be altered by the third procedure.

### Move Multiple Floating-Point Data Registers (MC6888X, MC68040)

**FMOVEM** 

An example of the calculation of this mask is as follows:

Nested calling sequence...

MOVE.W UNSAVED (A7),D7 Load the list of active registers not

saved at entry.

OR.W #WILL\_USE,D7 Combine with those active at this time

BSR PROC\_3

Upon return from a procedure, the restoration of the necessary registers follows the same convention, and the register mask generated during the save operation on entry is used to restore the required floating-point data registers:

Return to caller...

ADDQ.L #2,A7 Discard the list of registers not saved.

MOVE.B (A7) + ,D7 Get the saved register list (pop word,

use byte).

FMOVEM (A7) + D7 Restore the registers.

\*

RTS Return to the calling routine.

### Move Multiple Floating-Point Control Registers (MC6888X, MC68040)

**FMOVEM** 

**Operation:** Register List  $\rightarrow$  Destination

Source → Register List

Assembler FMOVEM.L < list > , < ea > Syntax: FMOVEM.L < ea > , < list >

**Attributes:** Size = (Long)

**Description:** Moves one or more 32-bit values into or out of the specified system control registers. Any combination of the three system control registers may be specified. The registers are always moved in the same order, regardless of the addressing mode used; the floating-point control register is moved first, followed by the floating-point status register, and the floating-point instruction address register is moved last. If a register is not selected for the transfer, the relative order of the transfer of the other registers is the same. The first register is transferred between the floating-point unit and the specified address, with successive registers located up through higher addresses.

For the MC68881, this instruction does not cause pending exceptions (other than protocol violations) to be reported. Furthermore, a write to the floating-point control register exception enable byte or the floating-point status register exception status byte connot generate a new exception, despite the value written.

When more than one register is moved, the memory or memory- alterable addressing modes can be used as shown in the addressing mode tables. If the addressing mode is predecrement, the address register is first decremented by the total size of the register images to be moved (i.e., four times the number of registers), and then the registers are transferred starting at the resultant address. For the postincrement addressing mode, the selected registers are transferred to or from the specified address, and then the address register is incremented by the total size of the register images transferred. If a single system control register is selected, the data register direct addressing mode may be used; if the only register selected is the floating-point instruction address register, then the address register direct addressing mode is allowed. Note that if a single register is selected, the opcode generated is the same as for the FMOVE single system control register instruction.

### Move Multiple Floating-Point Control Registers (MC6888X, MC68040)

## **FMOVEM**

**Floating-Point Status Register:** Changed only if thedestinationlist includes the floating-point status register in which case all bits are modified to reflect the value of the source register image.

#### **Instruction Format:**

| 15 | 14                  | 13 | 12          | 11               | 10 | 9 | 8 | 7 | 6 | 5     | 4       | 3 | 2       | 1 | 0            |  |  |  |
|----|---------------------|----|-------------|------------------|----|---|---|---|---|-------|---------|---|---------|---|--------------|--|--|--|
| 1  | 1 1 COPROCESSOR 0 0 | 4  | COPROCESSOR |                  |    |   |   |   |   | e EFF |         |   |         |   | TIVE ADDRESS |  |  |  |
| 1  | '                   | '  | '           | ID               |    | 0 | 0 | 0 |   | MODE  | MODE RE |   | EGISTER |   |              |  |  |  |
| 1  | 0                   | dr | R           | REGISTER<br>LIST |    | 0 | 0 | 0 | 0 | 0     | 0       | 0 | 0       | 0 | 0            |  |  |  |

#### **Instruction Fields:**

Effective Address field—Determines the addressing mode for the operation.

Memory-to-Register—Only control addressing modes or the postincrement addressing mode can be used as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn*                     | 000  | reg. number:Dn |
| An**                    | 001  | reg. number:An |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| - (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | 111  | 100      |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |
| ([bd,PC,Xn],od)         | 111  | 011      |
| ([bd,PC],Xn,od)         | 111  | 011      |

<sup>\*</sup>Only if a single floating-point instruction address register, floating-point status register, or floating-point control register is selected.

<sup>\*\*</sup>Only if the floating-point instruction address register is the single register selected.

### Move Multiple Floating-Point Control Registers (MC6888X, MC68040)

## **FMOVEM**

Register-to-Memory—Only control alterable addressing modes or the predecrement addressing mode can be used as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn*                     | 000  | reg. number:Dn |
| An**                    | 001  | reg. number:An |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| – (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | _    | _        |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | _    | _        |
| (d <sub>8</sub> ,PC,Xn) | _    | _        |
| (bd,PC,Xn)              | _    | _        |
| ([bd,PC,Xn],od)         | _    | _        |
| ([bd,PC],Xn,od)         | _    | _        |

<sup>\*</sup>Only if a single floating-point control register is selected.

dr field—Specifies the direction of the transfer.

- 0 Move the listed registers from memory to the floating-point unit.
- 1 Move the listed registers from the floating-point unit to memory.

Register List field—Contains the register select mask. If a register is to be moved, the corresponding bit in the list is set; otherwise, it is clear. At least one register must be specified.

| Bit Number | Register                                       |
|------------|------------------------------------------------|
| 12         | Floating-Point Control Register                |
| 11         | Floating-Point Status Register                 |
| 10         | Floating-Point Instruction<br>Address Register |

<sup>\*\*</sup>Only if the floating-point instruction address register is the single register selected.

# Floating-Point Multiply (MC6888X, MC68040)

**FMUL** 

**Operation:** Source x FPn  $\rightarrow$  FPn

**Assembler** FMUL. < fmt > < ea > ,FPn

**Syntax:** FMUL.X FPm,FPn

\*FrMUL < fmt > < ea > ,FPn

\*FrMUL.X FPm,FPn

where r is rounding precision, S or D

\*Supported by MC68040 only

**Attributes:** Format = (Byte, Word, Long, Single, Double, Extended, Packed)

**Description:** Converts the source operand to extended precision (if necessary) and multiplies that number by the number in the destination floating-point data register. Stores the result in the destination floating-point data register.

FMUL will round the result to the precision selected in the floating-point control register. FSMUL and FDMUL will round the result to single or double precision, respectively, regardless of the rounding precision selected in the floating-point control register.

### **Operation Table:**

|             |   |                | SOURCE <sup>1</sup> |               |                |                  |              |                |                  |                |
|-------------|---|----------------|---------------------|---------------|----------------|------------------|--------------|----------------|------------------|----------------|
| DESTINATION |   | +              | In Range            | _             | +              | Zero             | _            | +              | Infinity         | _              |
| In Range    | + |                | Multiply            |               | + 0.0<br>- 0.0 |                  | -0.0<br>+0.0 | + inf<br>– inf |                  | – inf<br>+ inf |
| Zero        | + | + 0.0<br>- 0.0 |                     | -0.0<br>+0.0  | + 0.0<br>- 0.0 |                  | -0.0<br>+0.0 |                | NAN <sup>2</sup> |                |
| Infinity    | + | + inf<br>– inf |                     | –inf<br>+ inf |                | NAN <sup>2</sup> |              | + inf<br>– inf |                  | – inf<br>+ inf |

#### NOTES:

- 1. If the source operand is a NAN, refer to 1.6.5 Not-A-Numbers for more information.
- 2. Sets the OPERR bit in the floating-point status register exception byte.

# Floating-Point Multiply (MC6888X, MC68040)

**FMUL** 

### Floating-Point Status Register:

Condition Codes: Affected as described in **3.6.2 Conditional Testing**.

Quotient Byte: Not affected.

Exception Byte: BSUN Cleared

SNAN Refer to **1.6.5 Not-A-Numbers**.

OPERR Set for 0 x infinity; cleared otherwise.

OVFL Refer to exception processing in the

appropriate user's manual.

UNFL Refer to exception processing in the

appropriate user's manual.

DZ Cleared

INEX2 Refer to exception processing in the

appropriate user's manual.

INEX1 If < fmt > is packed, refer to exception

processing in the appropriate user's manual;

cleared otherwise.

Accrued Exception Byte: Affected as described in exception processing in the appro-

priate user's manual.

#### **Instruction Format:**

| 15 | 14  | 13 | 12    | 11                  | 10 | 9           | 8       | 7 | 6 | 5       | 4  | 3       | 2       | 1   | 0 |
|----|-----|----|-------|---------------------|----|-------------|---------|---|---|---------|----|---------|---------|-----|---|
| 1  | 4   | 4  | 1     | COPR                |    | COPROCESSOR |         | _ |   |         | EF | FECTIVE | E ADDRI | ESS |   |
| ı  | 1   | '  | 1   1 | ID 0 0              | 0  |             | MODE    |   | F | REGISTE | R  |         |         |     |   |
| 0  | R/M | 0  | 1     | SOURCE<br>SPECIFIER |    |             | STINATI | - |   |         | (  | OPMOD   | E       |     |   |

### Floating-Point Multiply (MC6888X, MC68040)

## **FMUL**

#### **Instruction Fields:**

Effective Address field—Determines the addressing mode for external operands.

If R/M = 0, this field is unused and should be all zeros.

If R/M = 1, specifies the location of the source operand location. Only data addressing modes can be used as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn*                     | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| - (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | 111  | 100      |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |
| ([bd,PC,Xn],od)         | 111  | 011      |
| ([bd,PC],Xn,od)         | 111  | 011      |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

R/M field—Specifies the source operand address mode.

- 0 The operation is register to register.
- 1 The operation is < ea > to register.

Source Specifier field—Specifies the source register or data format.

If R/M = 0, specifies the source floating-point data register.

If R/M = 1, specifies the source data format:

- 000 Long-Word Integer (L)
- 001 Single-Precision Real (S)
- 010 Extended-Precision Real (X)
- 011 Packed-Decimal Real (P)\*
- 100 Word Integer (W)
- 101 Double-Precision Real (D)
- 110 Byte Integer (B)

<sup>\*</sup>This encoding will cause an unimplemented data type exception in the MC68040 to allow emulation in software.

# Floating-Point Multiply (MC6888X, MC68040)



Destination Register field—Specifies the destination floating- point data register.

Opmode field—Specifies the instruction and rounding precision.

| FMUL  | Rounding precision specified by the floating-point control register. |
|-------|----------------------------------------------------------------------|
| FSMUL | Single-precision rounding specified.                                 |
| FDMUL | Double-precision rounding specified.                                 |
|       | SMUL                                                                 |

FNEG Floating-Point Negate (MC6888X, MC68040) FNEG

**Operation:**  $- (Source) \rightarrow FPn$ 

**Assembler** FNEG. < fmt > < ea > ,FPn

**Syntax:** FNEG.X FPm,FPn

FNEG.X FPn

\*FrNEG. < fmt > < ea > ,FPn

\*FrNEG.X FPm,FPn \*FrNEG.X FPn

where r is rounding precision, S or D

\*Supported by MC68040 only

**Attributes:** Format = (Byte, Word, Long, Single, Double, Extended, Packed)

**Description:** Converts the source operand to extended precision (if necessary) and inverts the sign of the mantissa. Stores the result in the destination floating-point data register.

FNEG will round the result to the precision selected in the floating-point control register. FSNEG and FDNEG will round the result to single or double precision, respectively, regardless of the rounding precision selected in the floating-point control register.

#### **Operation Table:**

|             |            | SOURCE |        |       |          |     |  |  |  |  |  |
|-------------|------------|--------|--------|-------|----------|-----|--|--|--|--|--|
| DESTINATION | + In Range | - +    | Zero - | +     | Infinity | -   |  |  |  |  |  |
| Result      | Negate     | - 0.0  | + 0.0  | – inf | + i      | inf |  |  |  |  |  |

NOTE: If the source operand is a NAN, refer to 1.6.5 Not-A-Numbers for more information.

### **FNEG**

# Floating-Point Negate (MC6888X, MC68040)

## **FNEG**

#### Floating-Point Status Register:

Condition Codes: Affected as described in **3.6.2 Conditional Testing**.

Quotient Byte: Not affected.

Exception Byte: BSUN Cleared

SNAN Refer to **1.6.5 Not-A-Numbers**.

OPERR Cleared OVFL Cleared

UNFL If source is an extended-precision

denormalized number, refer to exception processing in the appropriate user's manual;

cleared otherwise.

DZ Cleared INEX2 Cleared

INEX1 If < fmt > is packed, refer to exception

processing in the appropriate user's manual;

cleared otherwise.

Accrued Exception Byte: Affected as described in exception processing in the appro-

priate user's manual.

#### **Instruction Format:**

| 15 | 14  | 13 | 12  | 11                | 10    | 9   | 8       | 7 | 6 | 5 | 4    | 3       | 2                     | 1   | 0 |
|----|-----|----|-----|-------------------|-------|-----|---------|---|---|---|------|---------|-----------------------|-----|---|
| 1  |     | 4  | 1   | COF               | ROCES | SOR |         | _ |   |   | EF   | FECTIVE | E ADDRI               | ESS |   |
| ı  | '   | '  | '   |                   | ID    |     | 0       | 0 |   |   | MODE |         | E ADDRESS<br>REGISTER | R   |   |
| 0  | R/M | 0  | l . | SOURCE<br>PECIFIE |       |     | STINATI | - |   |   | (    | OPMOD   | E                     |     |   |

**FNEG** 

# Floating-Point Negate (MC6888X, MC68040)

**FNEG** 

#### **Instruction Fields:**

Effective Address field—Determines the addressing mode for external operands.

If R/M = 0, this field is unused and should be all zeros.

If R/M = 1, specifies the location of the source operand. Only data addressing modes can be used as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn*                     | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| – (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | 111  | 100      |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |
| ([bd,PC,Xn],od)         | 111  | 011      |
| ([bd,PC],Xn,od)         | 111  | 011      |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

R/M field—Specifies the source operand address mode.

- 0 The operation is register to register.
- 1 The operation is < ea > to register.

Source Specifier field—Specifies the source register or data format.

If R/M = 0, specifies the source floating-point data register.

If R/M = 1, specifies the source data format:

- 000 Long-Word Integer (L)
- 001 Single-Precision Real (S)
- 010 Extended-Precision Real (X)
- 011 Packed-Decimal Real (P)\*
- 100 Word Integer (W)
- 101 Double-Precision Real (D)
- 110 Byte Integer (B)

<sup>\*</sup>This encoding will cause an unimplemented data type exception to allow emulation in software.

### **FNEG**

# Floating-Point Negate (MC6888X, MC68040)

**FNEG** 

Destination Register field—Specifies the destination floating- point data register. If R/ M = 0 and the source and destination fields are equal, then the input operand is taken from the specified floating-point data register and the result is written into the same register. If the single register syntax is used, Motorola assemblers set the source and destination fields to the same value.

Opmode field—Specifies the instruction and rounding precision.

| 0011010 | FNEG         | Rounding precision specified by the floating-point control register. |
|---------|--------------|----------------------------------------------------------------------|
| 1011010 | <b>FSNEG</b> | Single-precision rounding specified.                                 |
| 1011110 | <b>FDNEG</b> | Double-precision rounding specified.                                 |

FNOP

No Operation
(MC6888X, MC68040)

**FNOP** 

**Operation:** None

**Assembler** 

Syntax: FNOP

Attributes: Unsized

**Description:** This instruction does not perform any explicit operation. However, it is useful to force synchronization of the floating- point unit with an integer unit or to force processing of pending exceptions. For most floating-point instructions, the integer unit is allowed to continue with the execution of the next instruction once the floating-point unit has any operands needed for an operation, thus supporting concurrent execution of floating-point and integer instructions. The FNOP instruction synchronizes the floating-point unit and the integer unit by causing the integer unit to wait until all previous floating-point instructions have completed. Execution of FNOP also forces any exceptions pending from the execution of a previous floating-point instruction to be processed as a preinstruction exception.

The MC68882 may not wait to begin execution of another floating- point instruction until it has completed execution of the current instruction. The FNOP instruction synchronizes the coprocessor and microprocessor unit by causing the microprocessor unit to wait until the current instruction (or both instructions) have completed.

The FNOP instruction also forces the processing of exceptions pending from the execution of previous instructions. This is also inherent in the way that the floating-point coprocessor utilizes the M68000 family coprocessor interface. Once the floating-point coprocessor has received the input operand for an arithmetic instruction, it always releases the main processor to execute the next instruction (regardless of whether or not concurrent execution is prevented for the instruction due to tracing) without reporting the exception during the execution of that instruction. Then, when the main processor attempts to initiate the execution of the next floating-point coprocessor instruction, a preinstruction exception may be reported to initiate exception processing for an exception that occurred during a previous instruction. By using the FNOP instruction, the user can force any pending exceptions to be processed without performing any other operations.

Floating-Point Status Register: Not Affected.

**MOTOROLA** 

**FNOP** 

## No Operation (MC6888X, MC68040)

**FNOP** 

#### **Instruction Format:**

| 15 | 14 | 13 | 12 | 11   | 10     | 9     | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|------|--------|-------|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 1  | COPF | ROCESS | OR ID | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 0  | 0  | 0  | 0  | 0    | 0      | 0     | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

#### **Instruction Fields:**

Coprocessor ID field—Specifies which coprocessor in the system is to execute this instruction. Motorola assemblers default to ID = 1 for the floating-point coprocessor.

#### NOTE

FNOP uses the same opcode as the FBcc.W < label > instruction, with cc = F (nontrapping false) and < label > = + 2 (which results in a displacement of 0).

FREM
IEEE Remainder
(MC6888X, M68040FPSP)

FREM

**Operation:** IEEE Remainder of (FPn  $\div$  Source)  $\rightarrow$  FPn

**Assembler** FREM. < fmt > < ea > ,FPn

**Syntax:** FREM.X FPm,FPn

**Attributes:** Format = (Byte, Word, Long, Single, Double, Extended, Packed)

**Description:** Converts the source operand to extended precision (if necessary) and calculates the modulo remainder of the number in the destination floating-point data register, using the source operand as the modulus. Stores the result in the destination floating-point data register and stores the sign and seven least significant bits of the quotient in the floating-point status register quotient byte (the quotient is the result of FPn ÷ Source). The IEEE remainder function is defined as:

where N = INT (FPn ÷ Source) in the round-to-nearest mode.

The FREM function is not defined for a source operand equal to zero or for a destination operand equal to infinity. Note that this function is not the same as the FMOD instruction, which uses the round-to-zero mode and thus returns a remainder that is different from the remainder required by the IEEE *Specification for Binary Floating-Point Arithmetic*.

#### **Operation Table:**

|             |   |                  | SOURCE <sup>1</sup> |                  |
|-------------|---|------------------|---------------------|------------------|
| DESTINATION |   | + In Range -     | + Zero# -           | + Infinity -     |
| In Range    | + | IEEE Remainder   | NAN <sup>2</sup>    | FPn <sup>2</sup> |
| Zero        | + | + 0.0<br>- 0.0   | NAN <sup>2</sup>    | + 0.0<br>- 0.0   |
| Infinity    | + | NAN <sup>2</sup> | NAN <sup>2</sup>    | NAN†²            |

#### NOTES:

- 1. If the source operand is a NAN, refer to 1.6.5 Not-A-Numbers for more information.
- 2. Sets the OPERR bit in the floating-point status register exception byte.
- 3. Returns the value of FPn before the operation. However, the result is processed by the normal instruction termination procedure to round it as required. Thus, an overflow and/or inexact result may occur if the rounding precision has been changed to a smaller size since the FPn value was loaded.

## **FREM**

# IEEE Remainder (MC6888X, M68040FPSP)

### **FREM**

#### Floating-Point Status Register:

Condition Codes: Affected as described in **3.6.2 Conditional Testing**.

Quotient Byte: Loaded with the sign and least significant seven bits of the

qotient (FPn ÷ Source). The sign of the quotient is the exclusive-OR of the sign bits of the source and destination

operands.

Exception Byte: BSUN Cleared

SNAN Refer to **1.6.5 Not-A-Numbers**.

OPERR Set if the source is zero or the destination is

infinity; cleared otherwise.

OVFL Cleared

UNFL Refer to underflow in the appropriate user's

manual.

DZ Cleared NEX2 Cleared

INEX1 If < fmt > is packed, refer to inexact result on

decimal input in the appropriate user's

manual; cleared otherwise.

Accrued Exception Byte: Affected as described in IEEE exception and trap compati-

bility in the appropriate user's manual.

#### **Instruction Format:**

|   | 15 | 14  | 13 | 12 | 11                | 10    | 9   | 8       | 7 | 6 | 5                 | 4 | 3 | 2 | 1 | 0 |
|---|----|-----|----|----|-------------------|-------|-----|---------|---|---|-------------------|---|---|---|---|---|
| Γ | 1  | 1   | 1  | 1  | COF               | ROCES | SOR | 0       | 0 | _ | EFFECTIVE ADDRESS |   |   |   |   |   |
|   |    | '   | '  | '  |                   | ID    | 0   |         | 0 | " | MODE REGISTER     |   |   |   |   | R |
|   | 0  | R/M | 0  |    | SOURCE<br>PECIFIE |       |     | STINATI |   | 0 | 1                 | 0 | 0 | 1 | 0 | 1 |

#### Instruction Fields:

Coprocessor ID field—Specifies which coprocessor in the system is to execute this instruction. Motorola assemblers default to ID = 1 for the floating-point coprocessor.

**FREM** 

# IEEE Remainder (MC6888X, M68040FPSP)

**FREM** 

Effective Address field—Determines the addressing mode for external operands.

If R/M = 0, this field is unused and should be all zeros.

If R/M = 1, this field is encoded with an M68000 family addressing mode as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn*                     | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| – (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | 111  | 100      |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |
| ([bd,PC,Xn],od)         | 111  | 011      |
| ([bd,PC],Xn,od)         | 111  | 011      |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

R/M field—Specifies the source operand address mode.

- 0 The operation is register to register.
- 1 The operation is < ea > to register.

Source Specifier field—Specifies the source register or data format.

If R/M = 0, specifies the source floating-point data register.

If R/M = 1, specifies the source data format:

- 000 Long-Word Integer (L)
- 001 Single-Precision Real (S)
- 010 Extended-Precision Real (X)
- 011 Packed-Decimal Real (P)
- 100 Word Integer (W)
- 101 Double-Precision Real (D)
- 110 Byte Integer (B)

Destination Register field—Specifies the destination floating- point data register.

**FSCALE** 

## Scale Exponent (MC6888X, M68040FPSP)

**FSCALE** 

**Operation:** FPn x INT(2Source)  $\rightarrow$  FPn

**Assembler** FSCALE. < fmt > < ea > ,FPn

**Syntax:** FSCALE.X FPm,FPn

**Attributes:** Format = (Byte, Word, Long, Single, Double, Extended, Packed)

**Description:** Converts the source operand to an integer (if necessary) and adds that integer to the destination exponent. Stores the result in the destination floating-point data register. This function has the effect of multiplying the destination by 2<sup>Source</sup>, but is much faster than a multiply operation when the source is an integer value.

The floating-point coprocessor assumes that the scale factor is an integer value before the operation is executed. If not, the value is chopped (i.e., rounded using the round-to-zero mode) to an integer before it is added to the exponent. When the absolute value of the source operand is  $\geq 2^{14}$ , an overflow or underflow always results.

#### **Operation Table:**

|              |            | SOURCE <sup>1</sup> |              |                  |          |   |                  |  |  |  |  |
|--------------|------------|---------------------|--------------|------------------|----------|---|------------------|--|--|--|--|
| DESTINATION  | + In Range | _                   | - + Zero - + |                  | Infinity | _ |                  |  |  |  |  |
| In Range + - | Scale Expo | nent                |              | FPn <sup>2</sup> |          |   | NAN <sup>3</sup> |  |  |  |  |
| Zero + -     | + 0.0      | - 0.0               | + 0.0        |                  | - 0.0    |   | NAN <sup>3</sup> |  |  |  |  |
| Infinity + - | + inf      | – inf               | + inf        |                  | – inf    |   | NAN <sup>3</sup> |  |  |  |  |

#### NOTES:

- 1. If the source operand is a NAN, refer to 1.6.5 Not-A-Numbers for more information.
- Returns the value of FPn before the operation. However, the result is processed by the normal instruction termination procedure to round it as required. Thus, an overflow and/or inexact result may occur if the rounding precision has been changed to a smaller size since the FPn value was loaded.
- 3. Sets the OPERR bit in the floating-point status register exception byte.

**FSCALE** 

Scale Exponent (MC6888X, M68040FPSP)

**FSCALE** 

#### Floating-Point Status Register:

Condition Codes: Affected as described in **3.6.2 Conditional Testing**.

Quotient Byte: Not affected

Exception Byte: BSUN Cleared

SNAN Refer to **1.6.5 Not-A-Numbers**.

OPERR Set if the source operand is  $\pm$  infinity; cleared

otherwise.

OVFL Refer to overflow in the appropriate user's

manual.

UNFL Refer to underflow in the appropriate user's

manual.

DZ Cleared INEX2 Cleared

INEX1 If < fmt > is packed, refer to inexact result on

decimal input in the appropriate user's

manual; cleared otherwise.

Accrued Exception Byte: Affected as described in IEEE exception and trap compati-

bility in the appropriate user's manual.

#### Instruction Format:

| 15 | 14  | 13 | 12 | 11                | 10          | 9 | 8       | 7 | 6 | 5             | 4          | 3 | 2 | 1 | 0 |
|----|-----|----|----|-------------------|-------------|---|---------|---|---|---------------|------------|---|---|---|---|
| 1  | 1   | 1  | 1  | COF               | COPROCESSOR |   |         |   |   | EF            | VE ADDRESS |   |   |   |   |
| 1  | '   | '  | '  |                   | ID          |   | 0       |   | " | MODE REGISTER |            |   |   |   | R |
| 0  | R/M | 0  |    | SOURCE<br>PECIFIE |             |   | STINATI |   | 0 | 1             | 0          | 0 | 1 | 1 | 0 |

#### **Instruction Fields:**

Coprocessor ID field—Specifies which coprocessor in the system is to execute this instruction. Motorola assemblers default to ID = 1 for the floating-point coprocessor.

### **FSCALE**

# Scale Exponent (MC6888X, M68040FPSP)

## **FSCALE**

Effective Address field—Determines the addressing mode for external operands.

If R/M = 0, this field is unused and should be all zeros.

If R/M = 1, this field is encoded with an M68000 family addressing mode as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn*                     | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| – (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | 111  | 100      |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |
| ([bd,PC,Xn],od)         | 111  | 011      |
| ([bd,PC],Xn,od)         | 111  | 011      |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

R/M field—Specifies the source operand address mode.

0 — The operation is register to register.

1 — The operation is < ea > to register.

Source Specifier field—Specifies the source register or data format.

If R/M = 0, specifies the source floating-point data register.

If R/M = 1, specifies the source data format:

000 — Long-Word Integer (L)

001 — Single-Precision Real (S)

010 — Extended-Precision Real (X)

011 — Packed-Decimal Real (P)

100 — Word Integer (W)

101 — Double-Precision Real (D)

110 — Byte Integer (B)

Destination Register field—Specifies the destination floating- point data register.

FSCC Set According to Floating-Point Condition (MC6888X, MC68040)

**Operation:** If (Condition True)

Then 1s  $\rightarrow$  Destination Else 0s  $\rightarrow$  Destination

**Assembler** 

**Syntax:** FScc. < size > < ea >

**Attributes:** Size = (Byte)

**Description:** If the specified floating-point condition is true, sets the byte integer operand at the destination to TRUE (all ones); otherwise, sets the byte to FALSE (all zeros). The conditional specifier cc may select any one of the 32 floating-point conditional tests as described in **Table 3-23 Floating-Point Conditional Tests**.

#### Floating-Point Status Register:

Condition Codes: Not affected.

Quotient Byte: Not affected.

Exception Byte: BSUN Set if the NAN condition code is set and the

condition selected is an IEEE nonaware test.

SNAN Not Affected.
OPERR Not Affected.
OVFL Not Affected.
UNFL Not Affected.
DZ Not Affected.
INEX2 Not Affected.
INEX1 Not Affected.

Accrued Exception Byte: The IOP bit is set if the BSUN bit is set in the exception

byte. No other bit is affected.

**MOTOROLA** 

### **FScc**

# Set According to Floating-Point Condition (MC6888X, MC68040)

## **FScc**

#### **Instruction Format:**

| 15 | 14 | 13 | 12 | 11  | 10    | 9   | 8   | 7   | 6 | 5 | 4    | 3      | 2      | 1      | 0  |  |
|----|----|----|----|-----|-------|-----|-----|-----|---|---|------|--------|--------|--------|----|--|
| 1  | 1  | 1  | 1  | COF | ROCES | SOR | 0 0 | 0 0 | _ | 4 |      | EFF    | ECTIVE | ADDRE  | SS |  |
| '  | '  | '  | '  |     | ID    |     | "   | 0   | ' |   | MODE |        | R      | EGISTE | R  |  |
| 0  | 0  | 0  | 0  | 0   | 0     | 0   | 0   | 0   | 0 |   | CONE | ITIONA | L PRED | CATE   |    |  |

#### **Instruction Fields:**

Effective Address field—Specifies the addressing mode for the byte integer operand. Only data alterable addressing modes can be used as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn                      | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| - (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | _    | _        |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | _    | _        |
| (d <sub>8</sub> ,PC,Xn) | _    | _        |
| (bd,PC,Xn)              | _    | _        |
| ([bd,PC,Xn],od)         | _    | _        |
| ([bd,PC],Xn,od)         | _    | _        |
|                         |      |          |

Conditional Predicate field—Specifies one of 32 conditional tests as defined in **3.6.2 Conditional Testing**.

#### **NOTE**

When a BSUN exception occurs, a preinstruction exception is taken. If the exception handler returns without modifying the image of the program counter on the stack frame (to point to the instruction following the FScc), then it must clear the cause of the exception (by clearing the NAN bit or disabling the BSUN trap) or the exception occurs again immediately upon return to the routine that caused the exception.

**FSGLDIV** 

Single-Precision Divide (MC6888X, MC68040)

**FSGLDIV** 

**Operation:**  $FPn \div Source \rightarrow FPn$ 

**Assembler** FSGLDIV. < fmt > < ea > ,FPn **Syntax:** FSGLDIV.X FPm,FPn

**Attributes:** Format = (Byte, Word, Long, Single, Double, Extended, Packed)

**Description:** Converts the source operand to extended precision (if necessary) and divides that number into the number in the destination floating-point data register. Stores the result in the destination floating-point data register, rounded to single precision (despite the current rounding precision). This function is undefined for 0 ÷ 0 and infinity ÷ infinity.

Both the source and destination operands are assumed to be representable in the single-precision format. If either operand requires more than 24 bits of mantissa to be accurately represented, the extraneous mantissa bits are trancated prior to the division, hence the accuracy of the result is not guaranteed. Furthermore, the result exponent may exceed the range of single precision, regardless of the rounding precision selected in the floating-point control register mode control byte. Refer to **3.6.1 Underflow, Round, Overflow** for more information.

The accuracy of the result is not affected by the number of mantissa bits required to represent each input operand since the input operands just change to extended precision. The result mantissa is rounded to single precision, and the result exponent is rounded to extended precision, despite the rounding precision selected in the floating-point control register.

#### **Operation Table:**

|             |   |                               | SOURCE <sup>3,1</sup>                    |                  |                                         |                |                  |              |  |  |  |
|-------------|---|-------------------------------|------------------------------------------|------------------|-----------------------------------------|----------------|------------------|--------------|--|--|--|
| DESTINATION |   | + In Range -                  | +                                        | Zero             | -                                       | +              | Infinity         | _            |  |  |  |
| In Range    | + | Divide<br>(Single Precision)  | + inf <sup>2</sup><br>– inf <sup>2</sup> |                  | -inf <sup>2</sup><br>+ inf <sup>2</sup> | + 0.0<br>- 0.0 |                  | -0.0<br>+0.0 |  |  |  |
| Zero        | + | + 0.0<br>- 0.0 - 0.0<br>+ 0.0 |                                          | NAN <sup>3</sup> |                                         | + 0.0<br>- 0.0 |                  | -0.0<br>+0.0 |  |  |  |
| Infinity    | + | + inf — inf<br>— inf — tinf   | + inf<br>– inf                           |                  | –inf<br>+ inf                           |                | NAN <sup>3</sup> |              |  |  |  |

#### NOTES:

- 1. If the source operand is a NAN, refer to **1.6.5 Not-A-Numbers** for more information.
- 2. Sets the DZ bit in the floating-point status register exception byte.
- 3. Sets the OPERR bit in the floating-point status register exception byte.

## **FSGLDIV**

# Single-Precision Divide (MC6888X, MC68040)

## **FSGLDIV**

#### Floating-Point Status Register:

Condition Codes: Affected as described in **3.6.2 Conditional Testing**.

Quotient Byte: Not affected.

Exception Byte: BSUN Cleared

SNAN Refer to **1.6.5 Not-A-Numbers**. OPERR Set for  $0 \div 0$  or infinity  $\div$  infinity.

OVFL Refer to overflow in the appropriate user's

manual.

UNFL Refer to underflow in the appropriate user's

manual.

DZ Set if the source is zero and the destination is

in range; cleared otherwise.

INEX2 Refer to inexact result in the appropriate

user's manual.

INEX1 If < fmt > is packed, refer to the appropriate

user's manual for inexact result on decimal

input; cleared otherwise.

Accrued Exception Byte: Affected as described in IEEE exception and trap compati-

bility in the appropriate user's manual.

#### Instruction Format:

| 15 | 14  | 13 | 12                | 11                  | 10 | 9 | 8                       | 7 | 6 | 5                 | 4 | 3 | 2 | 1 | 0 |  |
|----|-----|----|-------------------|---------------------|----|---|-------------------------|---|---|-------------------|---|---|---|---|---|--|
| 1  | 1   | 1  | 1 COPROCESSOR 0 0 | COPROCESSOR         |    |   | 0                       |   |   | EFFECTIVE ADDRESS |   |   |   |   |   |  |
| '  | '   | '  | '                 |                     | ID |   | 0                       | 0 | U | MODE REGISTER     |   |   |   |   | R |  |
| 0  | R/M | 0  |                   | SOURCE<br>SPECIFIER |    |   | DESTINATION<br>REGISTER |   | 0 | 1                 | 0 | 0 | 1 | 0 | 0 |  |

#### **Instruction Fields:**

Coprocessor ID field—Specifies which coprocessor in the system is to execute this instruction. Motorola assemblers default to ID = 1 for the floating-point coprocessor.

## **FSGLDIV**

# Single-Precision Divide (MC6888X, MC68040)

## **FSGLDIV**

Effective Address field—Determines the addressing mode for external operands.

If R/M = 0, this field is unused and should be all zeros.

If R/M = 1, this field is encoded with an M68000 family addressing mode as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn*                     | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| – (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | 111  | 100      |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |
| ([bd,PC,Xn],od)         | 111  | 011      |
| ([bd,PC],Xn,od)         | 111  | 011      |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

R/M field—Specifies the source operand address mode.

- 0 The operation is register to register.
- 1 The operation is < ea > to register.

Source Specifier field—Specifies the source register or data format.

If R/M = 0, specifies the source floating-point data register.

If R/M = 1, specifies the source data format:

- 000 Long-Word Integer (L)
- 001 Single-Precision Real (S)
- 010 Extended-Precision Real (X)
- 011 Packed-Decimal Real (P)
- 100 Word Integer (W)
- 101 Double-Precision Real (D)
- 110 Byte Integer (B)

Destination Register field—Specifies the destination floating- point data register.

## **FSGLMUL**

# Single-Precision Multiply (MC6888X, MC68040)

### **FSGLMUL**

**Operation:** Source x FPn  $\rightarrow$  FPn

**Assembler** FSGLMUL. < fmt > < ea > ,FPn

**Syntax:** FSGLMUL.X FPm,FPn

**Attributes:** Format = (Byte, Word, Long, Single, Double, Extended, Packed)

**Description:** Converts the source operand to extended precision (if necessary) and multiplies that number by the number in the destination floating-point data register. Stores the result in the destination floating-point data register, rounded to single precision (regardless of the current rounding precision).

Both the source and destination operands are assumed to be representable in the single-precision format. If either operand requires more than 24 bits of mantissa to be accurately represented, the extraneous mantissa bits are truncated prior to the multipliction; hence, the accuracy of the result is not guaranteed. Furthermore, the result exponent may exceed the range of single precision, regardless of the rounding precision selected in the floating-point control register mode control byte. Refer to **3.6.1 Underflow, Round, Overflow** for more information.

#### **Operation Table:**

|             |   |                                | SOURCE <sup>1</sup> |              |                |                  |                |  |  |  |  |  |
|-------------|---|--------------------------------|---------------------|--------------|----------------|------------------|----------------|--|--|--|--|--|
| DESTINATION |   | + In Range -                   | +                   | Zero –       | +              | Infinity         | _              |  |  |  |  |  |
| In Range    | + | Multiply<br>(Single Precision) | + 0.0<br>- 0.0      | -0.0<br>+0.0 | + inf<br>– inf |                  | – inf<br>+ inf |  |  |  |  |  |
| Zero        | + | + 0.0<br>- 0.0                 | + 0.0<br>- 0.0      | -0.0<br>+0.0 |                | NAN <sup>2</sup> |                |  |  |  |  |  |
| Infinity    | + | + inf — inf<br>— inf — + inf   |                     | NAN          | + inf<br>– inf |                  | -inf<br>+inf   |  |  |  |  |  |

#### NOTES:

- 1. If the source operand is a NAN, refer to **1.6.5 Not-A-Numbers** for more information.
- 2. Sets the OPERR bit in the floating-point status register exception byte.

#### **NOTE**

The input operand mantissas truncate to single precision before the multiply operation. The result mantissa rounds to single precision despite the rounding precision selected in the floatingpoint control register.

## **FSGLMUL**

# Single-Precision Multiply (MC6888X, MC68040)

## **FSGLMUL**

#### Floating-Point Status Register:

Condition Codes: Affected as described in **3.6.2 Conditional Testing.** 

Quotient Byte: Not affected.

Exception Byte: BSUN Cleared

SNAN Refer to **1.6.5 Not-A-Numbers**.

OPERR Set if one operand is zero and the other is

infinity; cleared otherwise.

OVFL Refer to overflow in the appropriate user's

manual.

UNFL Refer to underflow in the appropriate user's

manual.

DZ Cleared

INEX2 Refer to inexact result in the appropriate

user's manual.

INEX1 If < fmt > is packed, refer to inexact result on

decimal input in the appropriate user's

manual; cleared otherwise.

Accrued Exception Byte: Affected as described in IEEE exception and trap compati-

bility in the appropriate user's manual.

#### **Instruction Format:**

| 15 | 14  | 13 | 12     | 11                | 10 | 9 | 8                 | 7 | 6               | 5    | 4 | 3 | 2        | 1 | 0 |
|----|-----|----|--------|-------------------|----|---|-------------------|---|-----------------|------|---|---|----------|---|---|
| 1  | 1   | 1  | 1 COPR | COPROCESSOR       |    |   | 0 0               |   | EFFECTIVE ADDRI |      |   |   | SS       |   |   |
| '  | '   | '  | '      |                   | ID |   |                   | " | U               | MODE |   |   | REGISTER |   |   |
| 0  | R/M | 0  |        | SOURCE<br>PECIFIE |    | 1 | STINATI<br>EGISTE | - | 0               | 1    | 0 | 0 | 1        | 1 | 1 |

#### **Instruction Fields:**

Coprocessor ID field—Specifies which coprocessor in the system is to execute this instruction. Motorola assemblers default to ID = 1 for the floating-point coprocessor.

### **FSGLMUL**

# Single-Precision Multiply (MC6888X, MC68040)

## **FSGLMUL**

Effective Address field—Determines the addressing mode for external operands.

If R/M = 0, this field is unused and should be all zeros.

If R/M = 1, this field is encoded with an M68000 family addressing mode as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn*                     | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| – (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | 111  | 100      |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |
| ([bd,PC,Xn],od)         | 111  | 011      |
| ([bd,PC],Xn,od)         | 111  | 011      |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

R/M field—Specifies the source operand address mode.

0 — The operation is register to register.

1 — The operation is < ea > to register.

Source Specifier field—Specifies the source register or data format.

If R/M = 0, specifies the source floating-point data register.

If R/M = 1, specifies the source data format:

000 — Long-Word Integer (L)

001 — Single-Precision Real (S)

010 — Extended-Precision Real (X) 011 — Packed-Decimal Real (P)

100 — Word Integer (W)

101 — Double-Precision Real (D)

110 — Byte Integer (B)

Destination Register field—Specifies the destination floating- point data register.

FSIN Sine FSIN (MC6888X, M68040FPSP)

**Operation:** Sine of Source  $\rightarrow$  FPn

**Assembler** FSIN. < fmt > < ea > ,FPn

**Syntax:** FSIN.X FPm,FPn

FSIN.X FPn

**Attributes:** Format = (Byte, Word, Long, Single, Double, Extended, Packed)

**Description:** Converts the source operand to extended precision (if necessary) and calculates the sine of that number. Stores the result in the destination floating-point data register. This function is not defined for source operands of  $\pm$  infinity. If the source operand is not in the range of  $[-2\pi...+2\pi]$ , the argument is reduced to within that range before the sine is calculated. However, large arguments may lose accuracy during reduction, and very large arguments (greater than approximately  $10^{20}$ ) lose all accuracy. The result is in the range of [-1...+1].

#### **Operation Table:**

|             |   |          |   | ,     | SOURCE1 |       |   |                  |   |
|-------------|---|----------|---|-------|---------|-------|---|------------------|---|
| DESTINATION | + | In Range | - | +     | Zero    | _     | + | Infinity         | - |
| Result      |   | Sine     |   | + 0.0 |         | - 0.0 |   | NAN <sup>2</sup> |   |

#### NOTES:

- 1. If the source operand is a NAN, refer to 1.6.5 Not-A-Numbers for more information.
- 2. Sets the OPERR bit in the floating-point status register exception byte.

#### Floating-Point Status Register:

Condition Codes: Affected as described in **3.6.2 Conditional Testing**.

Quotient Byte: Not affected.

# FSIN Sine (MC6888X, M68040FPSP)

Exception Byte: BSUN Cleared

SNAN Refer to **1.6.5 Not-A-Numbers**.

OPERR Set if the source is  $\pm$  infinity; cleared

otherwise.

OVFL Cleared

UNFL Refer to underflow in the appropriate user's

manual.

DZ Cleared

INEX2 Refer to inexact result in the appropriate

user's manual.

INEX1 If < fmt > is packed, refer to inexact result on

decimal input in the appropriate user's

manual; cleared otherwise.

Accrued Exception Byte: Affected as described in IEEE exception and trap compati-

bility in the appropriate user's manual.

#### **Instruction Format:**

| 15 | 14  | 13 | 12 | 11     | 10     | 9   | 8                 | 7 | 6 | 5 | 4    | 3       | 2       | 1      | 0 |
|----|-----|----|----|--------|--------|-----|-------------------|---|---|---|------|---------|---------|--------|---|
| 1  | 1   | 1  | 1  | COF    | PROCES | SOR | _                 | 0 |   |   | EF   | FECTIVE | E ADDRE | SS     |   |
| ı  | '   | '  | '  |        | ID     |     | "                 | 0 | " |   | MODE |         | R       | EGISTE | R |
| 0  | R/M | 0  |    | SOURCE |        | 1   | STINATI<br>EGISTE | - | 0 | 0 | 0    | 1       | 1       | 1      | 0 |

#### Instruction Fields:

Coprocessor ID field—Specifies which coprocessor in the system is to execute this instruction. Motorola assemblers default to ID = 1 for the floating-point coprocessor.

**FSIN** 

#### Sine (MC6888X, M68040FPSP)

**FSIN** 

Effective Address field—Determines the addressing mode for external operands.

If R/M = 0, this field is unused and should be all zeros.

If R/M = 1, this field is encoded with an M68000 family addressing mode as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn*                     | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| – (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | 111  | 100      |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |
| ([bd,PC,Xn],od)         | 111  | 011      |
| ([bd,PC],Xn,od)         | 111  | 011      |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

R/M field—Specifies the source operand address mode.

- 0 The operation is register to register.
- 1 The operation is < ea > to register.

Source Specifier field—Specifies the source register or data format.

If R/M = 0, specifies the source floating-point data register.

If R/M = 1, specifies the source data format:

- 000 Long-Word Integer (L)
- 001 Single-Precision Real (S)
- 010 Extended-Precision Real (X)
- 011 Packed-Decimal Real (P)
- 100 Word Integer (W)
- 101 Double-Precision Real (D)
- 110 Byte Integer (B)

Destination Register field—Specifies the destination floating- point data register. If R/ M = 0 and the source and destination fields are equal, then the input operand is taken from the specified floating-point data register, and the result is written into the same register. If the single register syntax is used, Motorola assemblers set the source and destination fields to the same value.

# Simultaneous Sine and Cosine (MC6888X, M68040FPSP)

**FSINCOS** 

**Operation:** Sine of Source  $\rightarrow$  FPs

Cosine of Source → FPc

**Assembler** FSINCOS. < fmt > < ea > ,FPc,FPs

**Syntax:** FSINCOS.X FPm,FPc,FPs

**Attributes:** Format = (Byte, Word, Long, Single, Double, Extended, Packed)

**Description:** Converts the source operand to extended precision (if necessary) and calculates both the sine and the cosine of that number. Calculates both functions simultaneously; thus, this instruction is significantly faster than performing separate FSIN and FCOS instructions. Loads the sine and cosine results into the destination floating-point data register. Sets the condition code bits according to the sine result. If FPs and FPc are specified to be the same register, the cosine result is first loaded into the register and then is overwritten with the sine result. This function is not defined for source operands of ± infinity.

If the source operand is not in the range of  $[-2\pi...+2\pi]$ , the argument is reduced to within that range before the sine and cosine are calculated. However, large arguments may lose accuracy during reduction, and very large arguments (greater than approximately  $10^{20}$ ) lose all accuracy. The results are in the range of [-1...+1].

#### **Operation Table:**

|             |   | SOURCE <sup>1</sup> |   |       |       |       |   |                  |   |  |
|-------------|---|---------------------|---|-------|-------|-------|---|------------------|---|--|
| DESTINATION | + | In Range            | _ | +     | Zero  | -     | + | Infinity         | _ |  |
| FPs         |   | Sine                |   | + 0.0 |       | - 0.0 |   | NAN <sup>2</sup> |   |  |
| FPc         |   | Cosine              |   |       | + 1.0 |       |   | NAN <sup>2</sup> |   |  |

#### NOTES:

- 1. If the source operand is a NAN, refer to **1.6.5 Not-A-Numbers** for more information.
- 2. Sets the OPERR bit in the floating-point status register exception byte.

# Simultaneous Sine and Cosine (MC6888X, M68040FPSP)

## **FSINCOS**

#### Floating-Point Status Register:

Condition Codes: Affected as described in **3.6.2 Conditional Testing** (for the

sine result).

Quotient Byte: Not affected.

Exception Byte: BSUN Cleared

SNAN Refer to **1.6.5 Not-A-Numbers**.

OPERR Set if the source is  $\pm$  infinity; cleared

otherwise.

OVFL Cleared

UNFL Set if a sine underflow occurs, in which case

the cosine result is 1. Cosine cannot underflow. Refer to underflow in the

appropriate user's manual.

DZ Cleared

INEX2 Refer to inexact result in the appropriate

user's manual.

INEX1 If < fmt > is packed, refer to inexact result on

decimal input in the appropriate user's

manual; cleared otherwise.

Accrued Exception Byte: Affected as described in IEEE exception and trap compati-

bility in the appropriate user's manual.

#### **Instruction Format:**

| 15 | 14       | 13 | 12 | 11      | 10          | 9   | 8           | 7   | 6 | 5       | 4    | 3       | 2    | 1       | 0   |
|----|----------|----|----|---------|-------------|-----|-------------|-----|---|---------|------|---------|------|---------|-----|
| 1  | 1        | 1  | 1  | COF     | COPROCESSOR |     | SOR 0       |     |   |         | EF   | FECTIVE | ADDR | ESS     |     |
|    | '        | '  | '  |         | ID          |     | 0           | 0   | " |         | MODE |         | F    | REGISTE | R   |
| 0  | R/M      | 0  | 1  | SOURCE  |             | 1   | DESTINATION |     | 0 | 1 1 1 0 |      | 0       |      | STINAT  |     |
| O  | 1 (/ 1/1 | "  | S  | PECIFIE | ₽R          | REC | GISTER,     | FPs | " |         |      | "       | RE   | GISTER  | FPc |

#### Instruction Fields:

Coprocessor ID field—Specifies which coprocessor in the system is to execute this instruction. Motorola assemblers default to ID = 1 for the floating-point coprocessor.

# Simultaneous Sine and Cosine (MC6888X, M68040FPSP)

## **FSINCOS**

Effective Address field—Determines the addressing mode for external operands.

If R/M = 0, this field is unused and should be all zeros.

If R/M = 1, this field is encoded with an M68000 family addressing mode as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn*                     | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| – (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | 111  | 100      |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |
| ([bd,PC,Xn],od)         | 111  | 011      |
| ([bd,PC],Xn,od)         | 111  | 011      |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

R/M field—Specifies the source operand address mode.

0 — The operation is register to register.

1 — The operation is < ea > to register.

Source Specifier field—Specifies the source register or data format.

If R/M = 0, specifies the source floating-point data register.

If R/M = 1, specifies the source data format:

000 — Long-Word Integer (L)

001 — Single-Precision Real (S)

010 — Extended-Precision Real (X)

011 — Packed-Decimal Real (P)

100 — Word Integer (W)

101 — Double-Precision Real (D)

110 — Byte Integer (B)

Destination Register, FPc field—Specifies the destination floating- point data register, FPc. The cosine result is stored in this register.

# Simultaneous Sine and Cosine (MC6888X, M68040FPSP)

**FSINCOS** 

Destination Register, FPs field—Specifies the destination floating- point data register, FPs. The sine result is stored in this register. If FPc and FPs specify the same floating-point data register, the sine result is stored in the register, and the cosine result is discarded.

If R/M = 0 and the source register field is equal to either of the destination register fields, the input operand is taken from the specified floating-point data register, and the appropriate result is written into the same register.

**FSINH** 

# Hyperbolic Sine (MC6888X, M68040FPSP)

**FSINH** 

**Operation:** Hyperbolic Sine of Source  $\rightarrow$  FPn

**Assembler** FSINH. < fmt > < ea > ,FPn

**Syntax:** FSINH.X FPm,FPn

FSINH.X FPn

**Attributes:** Format = (Byte, Word, Long, Single, Double, Extended, Packed)

**Description:** Converts the source operand to extended precision (if necessary) and calculates the hyperbolic sine of that number. Stores the result in the destination floating-point data register.

#### **Operation Table:**

|             |   |                 |   |       | SOURCE |       |       |          |       |
|-------------|---|-----------------|---|-------|--------|-------|-------|----------|-------|
| DESTINATION | + | In Range        | - | +     | Zero   | _     | +     | Infinity | -     |
| Result      |   | Hyperbolic Sine |   | + 0.0 |        | - 0.0 | + inf |          | – inf |

NOTE: If the source operand is a NAN, refer to 1.6.5 Not-A-Numbers for more information.

#### Floating-Point Status Register:

Condition Codes: Affected as described in **3.6.2 Conditional Testing**.

Quotient Byte: Not affected.

Exception Byte: BSUN Cleared

SNAN Refer to **1.6.5 Not-A-Numbers**.

OPERR Cleared

OVFL Refer to overflow in the appropriate user's

manual.

UNFL Refer to underflow in the appropriate user's

manual.

DZ Cleared

INEX2 Refer to inexact result in the appropriate

user's manual.

INEX1 If < fmt > is packed, refer to inexact result on

decimal input in the appropriate user's

manual; cleared otherwise.

Accrued Exception Byte: Affected as described in IEEE exception and trap compati-

bility in the appropriate user's manual.

**FSINH** 

# Hyperbolic Sine (MC6888X, M68040FPSP)

## **FSINH**

#### **Instruction Format:**

| 15 | 14  | 13 | 12 | 11                | 10    | 9   | 8                  | 7 | 6 | 5 | 4    | 3       | 2       | 1      | 0 |
|----|-----|----|----|-------------------|-------|-----|--------------------|---|---|---|------|---------|---------|--------|---|
| 1  | 1   | 1  | 1  | COF               | ROCES | SOR | 0                  | 0 | _ |   | EF   | FECTIVE | E ADDRE | SS     |   |
| '  | '   | '  | '  |                   | ID    |     | 0                  | " | " |   | MODE |         | R       | EGISTE | R |
| 0  | R/M | 0  |    | SOURCE<br>PECIFIE |       |     | STINATI<br>REGISTE |   | 0 | 0 | 0    | 0       | 0       | 1      | 0 |

#### **Instruction Fields:**

Coprocessor ID field—Specifies which coprocessor in the system is to execute this instruction. Motorola assemblers default to ID = 1 for the floating-point coprocessor.

Effective Address field—Determines the addressing mode for external operands.

If R/M = 0, this field is unused and should be all zeros.

If R/M = 1, this field is encoded with an M68000 family addressing mode as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn*                     | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| – (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |  |  |
|-------------------------|------|----------|--|--|
| (xxx).W                 | 111  | 000      |  |  |
| (xxx).L                 | 111  | 001      |  |  |
| # < data >              | 111  | 100      |  |  |
|                         |      |          |  |  |
|                         |      |          |  |  |
| (d <sub>16</sub> ,PC)   | 111  | 010      |  |  |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |  |  |
| (bd,PC,Xn)              | 111  | 011      |  |  |
| ([bd,PC,Xn],od)         | 111  | 011      |  |  |
| ([bd,PC],Xn,od)         | 111  | 011      |  |  |
|                         |      |          |  |  |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

### **FSINH**

## Hyperbolic Sine (MC6888X, M68040FPSP)

**FSINH** 

R/M field—Specifies the source operand address mode.

- 0 The operation is register to register.
- 1 The operation is < ea > to register.

Source Specifier field—Specifies the source register or data format.

If R/M = 0, specifies the source floating-point data register.

If R/M = 1, specifies the source data format:

- 000 Long-Word Integer (L)
- 001 Single-Precision Real (S)
- 010 Extended-Precision Real (X)
- 011 Packed-Decimal Real (P)
- 100 Word Integer (W)
- 101 Double-Precision Real (D)
- 110 Byte Integer (B)

Destination Register field—Specifies the destination floating- point data register. If R/ M = 0 and the source and destination fields are equal, the input operand is taken from the specified floating-point data register, and the result is written into the same register. If the single register syntax is used, Motorola assemblers set the source and destination fields to the same value.

Floating-Point Square Root (MC6888X, MC68040)

**FSQRT** 

**Operation:** Square Root of Source  $\rightarrow$  FPn

**Assembler** FSQRT. < fmt > < ea > ,FPn

**Syntax:** FSQRT.X FPm,FPn

FSQRT.X FPn

\*FrSQRT. < fmt > < ea > ,FPn

\*FrSQRT FPm,FPn \*FrSQRT FPn

where r is rounding precision, S or D

\*Supported by MC68040 only

**Attributes:** Format = (Byte, Word, Long, Single, Double, Extended, Packed)

**Description:** Converts the source operand to extended precision (if necessary) and calculates the square root of that number. Stores the result in the destination floating-point data register. This function is not defined for negative operands.

FSQRT will round the result to the precision selected in the floating-point control register. FSFSQRT and FDFSQRT will round the result to single or double precision, respectively, regardless of the rounding precision selected in the floating-point control register. Operation Table:

|             |            | SOURCE <sup>1</sup> |       |      |       |       |          |                  |  |  |  |  |
|-------------|------------|---------------------|-------|------|-------|-------|----------|------------------|--|--|--|--|
| DESTINATION | +          | In Range -          | +     | Zero | _     | +     | Infinity | _                |  |  |  |  |
| Result      | $\sqrt{x}$ | NAN <sup>2</sup>    | + 0.0 |      | - 0.0 | + inf |          | NAN <sup>2</sup> |  |  |  |  |

#### NOTES:

- 1. If the source operand is a NAN, refer to **1.6.5 Not-A-Numbers** for more information.
- 2. Sets the OPERR bit in the floating-point status register exception byte.

# Floating-Point Square Root (MC6888X, MC68040)

**FSQRT** 

#### Floating-Point Status Register:

Condition Codes: Affected as described in **3.6.2 Conditional Testing**.

Quotient Byte: Not affected.

Exception Byte: BSUN Cleared

SNAN Refer to **1.6.5 Not-A-Numbers**.

OPERR Set if the source operand is not zero and is

negative; cleared otherwise.

OVFL Cleared UNFL Cleared DZ Cleared

INEX2 Refer to exception processing in the

appropriate user's manual.

INEX1 If < fmt > is packed, refer to exception

processing in the appropriate user's manual;

cleared otherwise.

Accrued Exception Byte: Affected as described in exception processing in the appro-

priate user's manual.

#### **Instruction Format:**

| 15 | 14  | 13 | 12 | 11  | 10    | 9                       | 8 | 7      | 6 | 5 | 4    | 3      | 2     | 1       | 0 |
|----|-----|----|----|-----|-------|-------------------------|---|--------|---|---|------|--------|-------|---------|---|
| 1  | 1   | 1  | 1  | COP | ROCES | SOR 0                   |   | 0      | 0 |   | EFI  | ECTIVE | ADDRE | ESS     |   |
| '  | '   |    | '  |     | ID    |                         |   |        | " |   | MODE |        | F     | REGISTE | ₹ |
| 0  | R/M | 0  |    |     |       | DESTINATION<br>REGISTER |   | OPMODE |   |   |      |        |       |         |   |

# Floating-Point Square Root (MC6888X, MC68040)

**FSQRT** 

#### **Instruction Fields:**

Effective Address field—Determines the addressing mode for external operands.

If R/M = 0, this field is unused and should be all zeros.

If R/M = 1, specifies the location of the source operand. Only data addressing modes can be used as listed in the following table:

| Addressing Mode         | Mode | Register       | Addressing Mo           | de Mode | Register |
|-------------------------|------|----------------|-------------------------|---------|----------|
| Dn*                     | 000  | reg. number:Dn | (xxx).W                 | 111     | 000      |
| An                      | _    | _              | (xxx).L                 | 111     | 001      |
| (An)                    | 010  | reg. number:An | # < data >              | 111     | 100      |
| (An) +                  | 011  | reg. number:An |                         |         |          |
| – (An)                  | 100  | reg. number:An |                         |         |          |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An | (d <sub>16</sub> ,PC)   | 111     | 010      |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An | (d <sub>8</sub> ,PC,Xn) | 111     | 011      |
| (bd,An,Xn)              | 110  | reg. number:An | (bd,PC,Xn)              | 111     | 011      |
| ([bd,An,Xn],od)         | 110  | reg. number:An | ([bd,PC,Xn],oc          | ) 111   | 011      |
| ([bd,An],Xn,od)         | 110  | reg. number:An | ([bd,PC],Xn,oc          | ) 111   | 011      |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

R/M field—Specifies the source operand address mode.

- 0 The operation is register to register.
- 1 The operation is < ea > to register.

Source Specifier field—Specifies the source register or data format.

If R/M = 0, specifies the source floating-point data register.

If R/M = 1, specifies the source data format:

- 000 Long-Word Integer (L)
- 001 Single-Precision Real (S)
- 010 Extended-Precision Real (X)
- 011 Packed-Decimal Real (P)\*
- 100 Word Integer (W)
- 101 Double-Precision Real (D)
- 110 Byte Integer (B)

<sup>\*</sup>This encoding will cause an unimplemented data type exception in the MC68040 to allow emulation in software.

## Floating-Point Square Root (MC6888X, MC68040)

**FSQRT** 

Destination Register field—Specifies the destination floating- point data register. If R/ M = 0 and the source and destination fields are equal, the input operand is taken from the specified floating-point data register, and the result is written into the same register. If the single register syntax is used, Motorola assemblers set the source and destination fields to the same value.

Opmode field—Specifies the instruction and rounding precision.

| 0000100 | FSQRT         | Rounding precision specified by the floating-point control register. |
|---------|---------------|----------------------------------------------------------------------|
| 1000001 | <b>FSSQRT</b> | Single-precision rounding specified.                                 |
| 1000101 | <b>FDSQRT</b> | Double-precision rounding specified.                                 |

**FSUB** 

# Floating-Point Subtract (MC6888X, MC68040)

**FSUB** 

**Operation:**  $FPn - Source \rightarrow FPn$ 

**Assembler** 

**Syntax:** FSUB. < fmt > < ea > ,FPn

FSUB.X FPm,FPn

\*FrSUB. < fmt > < ea > ,FPn

\*FrSUB.X FPm,FPn

where r is rounding precision, S or D

\*Supported by MC68040 only

**Attributes:** Format = (Byte, Word, Long, Single, Double, Extended, Packed)

**Description:** Converts the source operand to extended precision (if necessary) and subtracts that number from the number in the destination floating-point data register. Stores the result in the destination floating-point data register.

#### **Operation Table:**

|             |   |                | SOURCE <sup>1</sup>         |                |                           |                           |          |                           |  |  |  |  |  |
|-------------|---|----------------|-----------------------------|----------------|---------------------------|---------------------------|----------|---------------------------|--|--|--|--|--|
| DESTINATION |   | + In Range -   | +                           | Zero           | -                         | +                         | Infinity | -                         |  |  |  |  |  |
| In Range    | + | Subtract       |                             | Subtract       |                           | – inf                     |          | + inf                     |  |  |  |  |  |
| Zero        | + | Subtract       | + 0.0 <sup>2</sup><br>+ 0.0 |                | +0.0<br>+0.0 <sup>2</sup> | – inf                     |          | +inf                      |  |  |  |  |  |
| Infinity    | + | + inf<br>– inf |                             | + inf<br>– inf |                           | NAN <sup>2</sup><br>– inf | 1        | – inf<br>NAN <sup>2</sup> |  |  |  |  |  |

#### NOTES:

- 1. If the source operand is a NAN, refer to **1.6.5 Not-A-Numbers** for more information.
- 2. Returns + 0.0 in rounding modes RN, RZ, and RP; returns 0.0 in RM.
- 3. Sets the OPERR bit in the floating-point status register exception byte.

## **FSUB**

# Floating-Point Subtract (MC6888X, MC68040)

**FSUB** 

#### Floating-Point Status Register:

Condition Codes: Affected as described in **3.6.2 Conditional Testing**.

Quotient Byte: Not affected.

Exception Byte: BSUN Cleared

SNAN Refer to **1.6.5 Not-A-Numbers**.

OPERR Set if both the source and destination are

like-signed infinities; cleared otherwise.

OVFL Refer to exception processing in the

appropriate user's manual.

UNFL Refer to exception processing in the

appropriate user's manual.

DZ Cleared

INEX2 Refer to exception processing in the

appropriate user's manual.

INEX1 If < fmt > is packed, refer to exception

processing in the appropriate user's manual;

cleared otherwise.

Accrued Exception Byte: Affected as described in IEEE exception and trap compati-

bility in the appropriate user's manual.

#### **Instruction Format:**

| 15 | 14  | 13 | 12 | 11          | 10 | 9                 | 8 | 7      | 6 | 5 | 4    | 3   | 2       | 1       | 0   |  |
|----|-----|----|----|-------------|----|-------------------|---|--------|---|---|------|-----|---------|---------|-----|--|
| 1  | 1   | 1  | 1  | COPROCESSOR |    |                   | _ |        | 0 | 0 |      | EFF | FECTIVE | ADDRE   | ESS |  |
| 1  |     | '  |    |             | ID |                   |   | 0      |   |   | MODE |     | F       | REGISTE | R   |  |
| 0  | R/M | 0  |    |             |    | STINATI<br>EGISTE |   | OPMODE |   |   |      |     |         |         |     |  |

### **FSUB**

## Floating-Point Subtract (MC6888X, MC68040)

### **FSUB**

### **Instruction Fields:**

Effective Address field—Determines the addressing mode for external operands.

If R/M = 0, this field is unused and should be all zeros.

If R/M = 1, specifies the location of the source operand. Only data addressing modes can be used as listed in the following table:

| Addressing Mode         | Mode | Register       |  | Addressing Mode         | Mode | Register |
|-------------------------|------|----------------|--|-------------------------|------|----------|
| Dn*                     | 000  | reg. number:Dn |  | (xxx).W                 | 111  | 000      |
| An                      | _    | _              |  | (xxx).L                 | 111  | 001      |
| (An)                    | 010  | reg. number:An |  | # < data >              | 111  | 100      |
| (An) +                  | 011  | reg. number:An |  |                         |      |          |
| – (An)                  | 100  | reg. number:An |  |                         |      |          |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |  | (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |  | (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,An,Xn)              | 110  | reg. number:An |  | (bd,PC,Xn)              | 111  | 011      |
| ([bd,An,Xn],od)         | 110  | reg. number:An |  | ([bd,PC,Xn],od)         | 111  | 011      |
| ([bd,An],Xn,od)         | 110  | reg. number:An |  | ([bd,PC],Xn,od)         | 111  | 011      |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

R/M field—Specifies the source operand address mode.

- 0 The operation is register to register.
- 1 The operation is < ea > to register.

Source Specifier field—Specifies the source register or data format.

If R/M = 0, specifies the source floating-point data register.

If R/M = 1, specifies the source data format:

- 000 Long-Word Integer (L)
- 001 Single-Precision Real (S)
- 010 Extended-Precision Real (X)
- 011 Packed-Decimal Real (P)\*
- 100 Word Integer (W)
- 101 Double-Precision Real (D)
- 110 Byte Integer (B)

<sup>\*</sup>This encoding will cause an unimplemented data type exception in the MC68040 to allow emulation in software.

**FSUB** 

## Floating-Point Subtract (MC6888X, MC68040)

**FSUB** 

Destination Register field—Specifies the destination floating- point data register.

Opmode field—Specifies the instruction and rounding precision.

| 0101000 | FSUB  | Rounding precision specified by the floating-point control register. |
|---------|-------|----------------------------------------------------------------------|
| 1101000 | FSSUB | Single-precision rounding specified.                                 |
| 1101100 | FDSUB | Double-precision rounding specified.                                 |
|         |       |                                                                      |

FTAN Tangent FTAN (MC6888X/004SW)

**Operation:** Tangent of Source  $\rightarrow$  FPn

**Assembler** FTAN. < fmt > < ea > ,FPn

**Syntax:** FTAN.X FPm,FPn

FTAN.X FPn

**Attributes:** Format = (Byte, Word, Long, Single, Double, Extended, Packed)

**Description:** Converts the source operand to extended precision (if necessary) and calculates the tangent of that number. Stores the result in the destination floating-point data register. This function is not defined for source operands of  $\pm$  infinity. If the source operand is not in the range of  $[-\pi/2...+\pi/2]$ , the argument is reduced to within that range before the tangent is calculated. However, large arguments may lose accuracy during reduction, and very large arguments (greater than approximately  $10^{20}$ ) lose all accuracy.

### **Operation Table:**

|             |   |          |   |       | SOURCE1 |       |   |                  |   |
|-------------|---|----------|---|-------|---------|-------|---|------------------|---|
| DESTINATION | + | In Range | - | +     | Zero    | _     | + | Infinity         | - |
| Result      |   | Tangent  |   | + 0.0 |         | - 0.0 |   | NAN <sup>2</sup> |   |

#### NOTES:

- 1. If the source operand is a NAN, refer to 1.6.5 Not-A-Numbers for more information.
- 2. Sets the OPERR bit in the floating-point status register exception byte.

## FTAN

## Tangent (MC6888X/004SW)

**FTAN** 

### Floating-Point Status Register:

Condition Codes: Affected as described in **3.6.2 Conditional Testing**.

Quotient Byte: Not affected.

Exception Byte: BSUN Cleared

SNAN Refer to **1.6.5 Not-A-Numbers**.

OPERR Set if the source is ± infinity; cleared

otherwise.

OVFL Refer to overflow in the appropriate user's

manual.

UNFL Refer to underflow in the appropriate user's

manual.

DZ Cleared

INEX2 Refer to inexact result in the appropriate

user's manual.

INEX1 If < fmt > is packed, refer to inexact result on

decimal input in the appropriate user's

manual; cleared otherwise.

Accrued Exception Byte: Affected as described in IEEE exception and trap compati-

bility in the appropriate user's manual.

#### Instruction Format:

| 15 | 14  | 13 | 12    | 11                | 10          | 9 | 8                 | 7 | 6 | 5 | 4    | 3       | 2     | 1       | 0 |
|----|-----|----|-------|-------------------|-------------|---|-------------------|---|---|---|------|---------|-------|---------|---|
| 1  | 1   | 1  | 1     | COF               | COPROCESSOR |   |                   | 0 |   |   | EF   | FECTIVE | ADDRE | ESS     |   |
| '  | '   | 1  | '   ' |                   | ID          |   | 0                 | 0 |   |   | MODE |         | F     | REGISTE | R |
| 0  | R/M | 0  |       | SOURCE<br>PECIFIE |             |   | STINATI<br>EGISTE |   | 0 | 0 | 0    | 1       | 1     | 1       | 1 |

### **Instruction Fields:**

Coprocessor ID field—Specifies which coprocessor in the system is to execute this instruction. Motorola assemblers default to ID = 1 for the floating-point coprocessor.

**FTAN** 

## Tangent (MC6888X/004SW)

**FTAN** 

Effective Address field—Determines the addressing mode for external operands.

If R/M = 0, this field is unused and should be all zeros.

If R/M = 1, this field is encoded with an M68000 family addressing mode as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn*                     | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| – (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | 111  | 100      |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |
| ([bd,PC,Xn],od)         | 111  | 011      |
| ([bd,PC],Xn,od)         | 111  | 011      |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

R/M field—Specifies the source operand address mode.

- 0 The operation is register to register.
- 1 The operation is < ea > to register.

Source Specifier field—Specifies the source register or data format.

If R/M = 0, specifies the source floating-point data register.

If R/M = 1, specifies the source data format:

- 000 Long-Word Integer (L)
- 001 Single-Precision Real (S)
- 010 Extended-Precision Real (X)
- 011 Packed-Decimal Real (P)
- 100 Word Integer (W)
- 101 Double-Precision Real (D)
- 110 Byte Integer (B)

Destination Register field—Specifies the destination floating- point data register. If R/ M = 0 and the source and destination fields are equal, the input operand is taken from the specified floating-point data register, and the result is written into the same register. If the single register syntax is used, Motorola assemblers set the source and destination fields to the same value.

FTANH

**Hyperbolic Tangent** (MC6888X, M68040FPSP)

**FTANH** 

**Operation:** Hyperbolic Tangent of Source  $\rightarrow$  FPn

**Assembler** FTANH. < fmt > < ea > ,FPn

Syntax: FTANH.X FPm,FPn FTANH.X FPn

Attributes: Format = (Byte, Word, Long, Single, Double, Extended, Packed)

**Description:** Converts the source operand to extended precision (if necessary) and calculates the hyperbolic tangent of that number. Stores the result in the destination floating-point data register.

### **Operation Table:**

| DESTINATION |                    |       | SOURCE |       |       |          |      |
|-------------|--------------------|-------|--------|-------|-------|----------|------|
|             | + In Range         | - +   | Zero   | _     | +     | Infinity | -    |
| Result      | Hyperbolic Tangent | + 0.0 |        | - 0.0 | + 1.0 |          | -1.0 |

NOTE: If the source operand is a NAN, refer to 1.6.5 Not-A-Numbers for more information.

### Floating-Point Status Register:

Condition Codes: Affected as described in **3.6.2 Conditional Testing**.

Quotient Byte: Not affected.

Exception Byte: BSUN Cleared

SNAN Refer to **1.6.5 Not-A-Numbers**.

OPERR Cleared OVFL Cleared

UNFL Refer to underflow in the appropriate user's

manual.

DZ Cleared

INEX2 Refer to inexact result in the appropriate

user's manual.

INEX1 If < fmt > is packed, refer to inexact result on

decimal input in the appropriate user's

manual; cleared otherwise.

Accrued Exception Byte: Affected as described in IEEE exception and trap compati-

bility in the appropriate user's manual.

### **FTANH**

## **Hyperbolic Tangent** (MC6888X, M68040FPSP)

### **FTANH**

### **Instruction Format:**

| 1 | 5 | 14  | 13 | 12 | 11                | 11 10 9     |     | 8                  | 7 | 6   | 5             | 4                 | 3 | 2 | 1 | 0 |  |
|---|---|-----|----|----|-------------------|-------------|-----|--------------------|---|-----|---------------|-------------------|---|---|---|---|--|
|   |   | 1   | 1  | 1  | COF               | COPROCESSOR |     |                    | 0 | 0 0 |               | EFFECTIVE ADDRESS |   |   |   |   |  |
|   | 1 | 1   | '  | '  |                   | ID          | 0   |                    | 0 | "   | MODE REGISTER |                   |   |   |   |   |  |
| ( | ) | R/M | 0  |    | SOURCE<br>PECIFIE |             | l . | STINATI<br>REGISTE |   | 0   | 0             | 0                 | 1 | 0 | 0 | 1 |  |

### Instruction Fields:

Coprocessor ID field—Specifies which coprocessor in the system is to execute this instruction. Motorola assemblers default to ID = 1 for the floating-point coprocessor.

Effective Address field—Determines the addressing mode for external operands.

If R/M = 0, this field is unused and should be all zeros.

If R/M = 1, this field is encoded with an M68000 family addressing mode as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn*                     | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| - (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | 111  | 100      |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |
| ([bd,PC,Xn],od)         | 111  | 011      |
| ([bd,PC],Xn,od)         | 111  | 011      |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

R/M field—Specifies the source operand address mode.

- 0 The operation is register to register.
- 1 The operation is < ea > to register.

### **FTANH**

## **Hyperbolic Tangent** (MC6888X, M68040FPSP)

**FTANH** 

Source Specifier field—Specifies the source register or data format.

If R/M = 0, specifies the source floating-point data register.

If R/M = 1, specifies the source data format:

000 — Long-Word Integer (L)

001 — Single-Precision Real (S)

010 — Extended-Precision Real (X)

011 — Packed-Decimal Real (P)

100 — Word Integer (W)

101 — Double-Precision Real (D)

110 — Byte Integer (B)

Destination Register field—Specifies the destination floating- point data register. If R/ M = 0 and the source and destination fields are equal, the input operand is taken from the specified floating-point data register, and the result is written into the same register. If the single register syntax is used, Motorola assemblers set the source and destination fields to the same value.

**FTENTOX** 

10<sup>x</sup>

**FTENTOX** 

(MC6888X, M68040FPSP)

10<sup>Source</sup> → FPn **Operation:** 

**Assembler** FTENTOX. < fmt > < ea > ,FPn

Syntax: FTENTOX.X FPm,FPn

FTENTOX.X FPn

Attributes: Format = (Byte, Word, Long, Single, Double, Extended, Packed)

**Description:** Converts the source operand to extended precision (if necessary) and calculates 10 to the power of that number. Stores the result in the destination floatingpoint data register.

### **Operation Table:**

| DESTINATION |   |                 |   |   | SOURCE |       |          |      |
|-------------|---|-----------------|---|---|--------|-------|----------|------|
|             | + | In Range        | _ | + | Zero – | +     | Infinity | -    |
| Result      |   | 10 <sup>x</sup> |   |   | + 1.0  | + inf |          | +0.0 |

NOTE: If the source operand is a NAN, refer to 1.6.5 Not-A-Numbers for more information.

### Floating-Point Status Register:

Condition Codes: Affected as described in **3.6.2 Conditional Testing**.

Quotient Byte: Not affected.

**Exception Byte: BSUN** Cleared

> SNAN Refer to 1.6.5 Not-A-Numbers.

**OPERR** Cleared

OVFL Refer to overflow in the appropriate user's

manual.

UNFL Refer to underflow in the appropriate user's

manual.

DΖ Cleared

INEX2 Refer to inexact result in the appropriate

user's manual.

INEX1 If < fmt > is packed, refer to the appropriate

user's manual inexact result on decimal

input; cleared otherwise.

Affected as described in IEEE exception and trap compati-Accrued Exception Byte:

bility in the appropriate user's manual.

### **FTENTOX**

### 10<sup>X</sup> (MC6888X, M68040FPSP)

### **FTENTOX**

#### **Instruction Format:**

| 15 | 14  | 13 | 12 | 11                | 11 10 9     |   | 8                  | 7   | 6 | 5                 | 4 | 3 | 2 | 1 | 0 |
|----|-----|----|----|-------------------|-------------|---|--------------------|-----|---|-------------------|---|---|---|---|---|
| 1  | 1   | 1  | 1  | COP               | COPROCESSOR |   | 0                  | 0 0 |   | EFFECTIVE ADDRESS |   |   |   |   |   |
| 1  | 1   | '  | '  |                   | ID          | 0 |                    | 0   | " | MODE REGISTER     |   |   |   |   |   |
| 0  | R/M | 0  |    | SOURCE<br>PECIFIE |             |   | STINATI<br>REGISTE |     | 0 | 0                 | 1 | 0 | 0 | 1 | 0 |

### **Instruction Fields:**

Coprocessor ID field—Specifies which coprocessor in the system is to execute this instruction. Motorola assemblers default to ID = 1 for the floating-point coprocessor.

Effective Address field—Determines the addressing mode for external operands.

If R/M = 0, this field is unused and should be all zeros.

If R/M = 1, this field is encoded with an M68000 family addressing mode as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn*                     | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| – (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | 111  | 100      |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |
| ([bd,PC,Xn],od)         | 111  | 011      |
| ([bd,PC],Xn,od)         | 111  | 011      |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

### **FTENTOX**

### 10<sup>x</sup> (MC6888X, M68040FPSP)

**FTENTOX** 

R/M field—Specifies the source operand address mode.

- 0 The operation is register to register.
- 1 The operation is < ea > to register.

Source Specifier field—Specifies the source register or data format.

If R/M = 0, specifies the source floating-point data register.

If R/M = 1, specifies the source data format:

- 000 Long-Word Integer (L)
- 001 Single-Precision Real (S)
- 010 Extended-Precision Real (X)
- 011 Packed-Decimal Real (P)
- 100 Word Integer (W)
- 101 Double-Precision Real (D)
- 110 Byte Integer (B)

Destination Register field—Specifies the destination floating- point data register. If R/ M = 0 and the source and destination fields are equal, the input operand is taken from the specified floating-point data register, and the result is written into the same register. If the single register syntax is used, Motorola assemblers set the source and destination fields to the same value.

# FTRAPCC Trap on Floating-Point Condition (MC6888X, MC68040)

**FTRAPcc** 

**Operation:** If Condition True

Then TRAP

**Assembler** FTRAPcc

**Syntax:** FTRAPcc.W # < data >

FTRAPcc.L # < data >

**Attributes:** Size = (Word, Long)

**Description:** If the selected condition is true, the processor initiates exception processing. A vector number is generated to reference the TRAPcc exception vector. The stacked program counter points to the next instruction. If the selected condition is not true, there is no operation performed and execution continues with the next instruction in sequence. The immediate data operand is placed in the word(s) following the conditional predicate word and is available for user definition for use within the trap handler.

The conditional specifier cc selects one of the 32 conditional tests defined in **3.6.2 Conditional Testing**.

### Floating-Point Status Register:

Condition Codes: Not affected.

Quotient Byte: Not affected.

Exception Byte: BSUN Set if the NAN condition code is set and the

condition selected is an IEEE nonaware test.

SNAN Not Affected.
OPERR Not Affected.
OVFL Not Affected.
UNFL Not Affected.
DZ Not Affected.
INEX2 Not Affected.
INEX1 Not Affected.

Accrued Exception Byte: The IOP bit is set if the BSUN bit is set in the exception

byte; no other bit is affected.

### **FTRAPcc**

## Trap on Floating-Point Condition (MC6888X, MC68040)

## **FTRAPcc**

#### **Instruction Format:**

| 15 | 14                                                                   | 13 | 12 | 11  | 10          | 9   | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1    | 0 |
|----|----------------------------------------------------------------------|----|----|-----|-------------|-----|---|---|---|---|---|---|---|------|---|
| 1  | 1                                                                    | 1  | 1  | COP | ROCES<br>ID | SOR | 0 | 0 | 1 | 1 | 1 | 1 |   | MODE |   |
| 0  | 0 0 0 0 0 0 0 0 0 0 CONDITIONAL PREDICATE                            |    |    |     |             |     |   |   |   |   |   |   |   |      |   |
|    | 16-BIT OPERAND OR MOST SIGNIFICANT WORD OF 32-BIT OPERAND (IFNEEDED) |    |    |     |             |     |   |   |   |   |   |   |   |      |   |
|    | LEAST SIGNIFICANT WORD OR 32-BIT OPERAND (IF NEEDED)                 |    |    |     |             |     |   |   |   |   |   |   |   |      |   |

#### Instruction Fields:

Mode field—Specifies the form of the instruction.

010 — The instruction is followed by a word operand.

011 — The instruction is followed by a long-word operand.

100 — The instruction has no operand.

Conditional Predicate field—Specifies one of 32 conditional tests as described in **3.6.2 Conditional Testing**.

Operand field—Contains an optional word or long-word operand that is user defined.

### **NOTE**

When a BSUN exception occurs, a preinstruction exception is taken by the main processor. If the exception handler returns without modifying the image of the program counter on the stack frame (to point to the instruction following the FTRAPcc), it must clear the cause of the exception (by clearing the NAN bit or disabling the BSUN trap), or the exception occurs again immediately upon return to the routine that caused the exception.

**FTST** 

## Test Floating-Point Operand (MC6888X, MC68040)

**FTST** 

**Operation:** Condition Codes for Operand  $\rightarrow$  FPCC

**Assembler** FTST. < fmt > < ea >

**Syntax:** FTST.X FPm

**Attributes:** Format = (Byte, Word, Long, Single, Double, Extended, Packed)

**Description:** Converts the source operand to extended precision (if necessary) and sets the condition code bits according to the data type of the result.

**Operation Table:** The contents of this table differfromtheother operation tables. A letter in an entry of this table indicates that the designated condition code bit is always set by the FTST operation. All unspecified condition code bits are cleared during the operation.

|             |      | SOURCE   |   |   |        |    |            |    |
|-------------|------|----------|---|---|--------|----|------------|----|
| DESTINATION | +    | In Range | - | + | Zero - | -[ | + Infinity | -  |
| Result      | none |          | N | Z | NZ     | Z  | l          | NI |

NOTE: If the source operand is a NAN, set the NAN condition code bit. If the source operand is an SNAN, set the SNAN bit in the floating-point status register exception byte

### Floating-Point Status Register:

Condition Codes: Affected as described in **3.6.2 Conditional Testing**.

Quotient Byte: Not affected.

Exception Byte: BSUN Cleared

SNAN Refer to **1.6.5 Not-A-Numbers**.

OPERR Cleared
OVFL Cleared
UNFL Cleared
DZ Cleared
INEX2 Cleared

INEX1 If < fmt > is packed, refer to exception

processing in the appropriate user's manual;

cleared otherwise.

Accrued Exception Byte: Affected as described in exception processing in the appro-

priate user's manual.

**FTST** 

## Test Floating-Point Operand (MC6888X, MC68040)

**FTST** 

### **Instruction Format:**

| 15 | 14  | 13 | 12 | 11                | 10    | 9   | 8                  | 7 | 6        | 5 | 4     | 3     | 2 | 1      | 0 |
|----|-----|----|----|-------------------|-------|-----|--------------------|---|----------|---|-------|-------|---|--------|---|
| 1  | 1   | 1  | 1  | COP               | ROCES | SOR | 0                  | 0 | effectiv |   | ADDRE | DRESS |   |        |   |
| '  | '   | '  | '  |                   | ID    |     | 0                  | 0 | "        |   | MODE  |       | R | EGISTE | R |
| 0  | R/M | 0  |    | SOURCE<br>PECIFIE |       |     | STINATI<br>REGISTE |   | 0        | 1 | 1     | 1     | 0 | 1      | 0 |

### **Instruction Fields:**

Effective Address field—Determines the addressing mode for external operands.

If R/M = 0, this field is unused and should be all zeros.

If R/M = 1, specifies the location of the source operand. Only data addressing modes can be used as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn*                     | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| – (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | 111  | 100      |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |
| ([bd,PC,Xn],od)         | 111  | 011      |
| ([bd,PC],Xn,od)         | 111  | 011      |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

### **FTST**

## Test Floating-Point Operand (MC6888X, MC68040)

**FTST** 

R/M field—Specifies the source operand address mode.

- 0 The operation is register to register.
- 1 The operation is < ea > to register.

Source Specifier field—Specifies the source register or data format.

If R/M = 0, specifies the source floating-point data register.

If R/M = 1, specifies the source data format:

000 — Long-Word Integer (L)

001 — Single-Precision Real (S)

010 — Extended-Precision Real (X)

011 — Packed-Decimal Real (P)\*

100 — Word Integer (W)

101 — Double-Precision Real (D)

110 — Byte Integer (B)

\*This encoding will cause an unimplemented data type exception in the MC68040 to allow emulation in software.

Destination Register field—Since the floating-point unit uses a common command word format for all of the arithmetic instructions (including FTST), this field is treated in the same manner for FTST as for the other arithmetic instructions, even though the destination register is not modified. This field should be set to zero to maintain compatibility with future devices; however, the floating-point unit does not signal an illegal instruction trap if it is not zero.

**FTWOTOX** 

2<sup>X</sup>

**FTWOTOX** 

(MC6888X, M68040FPSP)

**Operation:**  $2^{\text{Source}} \rightarrow \text{FPn}$ 

**Assembler** FTWOTOX. < fmt > < ea > ,FPn

**Syntax:** FTWOTOX.X FPm,FPn

FTWOTOX.X FPn

**Attributes:** Format = (Byte, Word, Long, Single, Double, Extended, Packed)

**Description:** Converts the source operand to extended precision (if necessary) and calculates two to the power of that number. Stores the result in the destination floating-point data register.

### **Operation Table:**

|             | SOURCE         |     |       |       |            |  |  |  |
|-------------|----------------|-----|-------|-------|------------|--|--|--|
| DESTINATION | + In Range     | - + | Zero  | - +   | Infinity – |  |  |  |
| Result      | 2 <sup>x</sup> |     | + 1.0 | + inf | +0.0       |  |  |  |

NOTE: If the source operand is a NAN, refer to 1.6.5 Not-A-Numbers for more information.

### Floating-Point Status Register:

Condition Codes: Affected as described in **3.6.2 Conditional Testing**.

Quotient Byte: Not affected.

Exception Byte: BSUN Cleared

SNAN Refer to **1.6.5 Not-A-Numbers**.

OPERR Cleared

OVFL Refer to overflow in the appropriate user's

manual.

UNFL Refer to underflow in the appropriate user's

manual.

DZ Cleared

INEX2 Refer to inexact result in the appropriate

user's manual.

INEX1 If < fmt > is packed, refer to inexact result on

decimal input in the appropriate user's

manual; cleared otherwise.

Accrued Exception Byte: Affected as described in IEEE exception and trap compati-

bility in the appropriate user's manual.

### **FTWOTOX**

### 2<sup>x</sup> (MC6888X, M68040FPSP)

### **FTWOTOX**

#### **Instruction Format:**

| 15 | 14  | 13 | 12 | 11                | 10    | 9   | 8                  | 7     | 6 | 5             | 4  | 3       | 2     | 1  | 0 |
|----|-----|----|----|-------------------|-------|-----|--------------------|-------|---|---------------|----|---------|-------|----|---|
| 1  | 1   | 1  | 1  | COF               | ROCES | SOR | 0                  | 0     | _ |               | EF | FECTIVE | ADDRE | SS |   |
| '  | '   | '  | '  |                   | ID    |     | "                  | 0 0 0 | " | MODE REGISTER |    |         |       | R  |   |
| 0  | R/M | 0  |    | SOURCE<br>PECIFIE |       | l . | STINATI<br>REGISTE | -     | 0 | 0             | 1  | 0       | 0     | 0  | 1 |

### **Instruction Fields:**

Coprocessor ID field—Specifies which coprocessor in the system is to execute this instruction. Motorola assemblers default to ID = 1 for the floating-point coprocessor.

Effective Address field—Determines the addressing mode for external operands.

If R/M = 0, this field is unused and should be all zeros.

If R/M = 1, this field is encoded with an M68000 family addressing mode as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn*                     | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| - (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn],od)         | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | 111  | 100      |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |
| ([bd,PC,Xn],od)         | 111  | 011      |
| ([bd,PC],Xn,od)         | 111  | 011      |

<sup>\*</sup>Only if < fmt > is byte, word, long, or single.

### **FTWOTOX**

### 2<sup>X</sup>

### **FTWOTOX**

### (MC6888X, M68040FPSP)

R/M field—Specifies the source operand address mode.

- 0 The operation is register to register.
- 1 The operation is < ea > to register.

Source Specifier field—Specifies the source register or data format.

If R/M = 0, specifies the source floating-point data register.

If R/M = 1, specifies the source data format:

- 000 Long-Word Integer (L)
- 001 Single-Precision Real (S)
- 010 Extended-Precision Real (X)
- 011 Packed-Decimal Real (P)
- 100 Word Integer (W)
- 101 Double-Precision Real (D)
- 110 Byte Integer (B)

Destination Register field—Specifies the destination floating- point data register. If R/ M = 0 and the source and destination fields are equal, the input operand is taken from the specified floating-point data register, and the result is written into the same register. If the single register syntax is used, Motorola assemblers set the source and destination fields to the same value.

# SECTION 6 SUPERVISOR (PRIVILEGED) INSTRUCTIONS

This section contains information about the supervisor privileged instructions for the M68000 family. Each instruction is described in detail, and the instruction descriptions are arranged in alphabetical order by instruction mnemonic.

Any differences within the M68000 family of instructions are identified in the instruction. If an instruction only applies to a certain processor or processors, the processor(s) that the instruction pertains to is identified under the title of the instruction. For example:

## Invalidate Cache Lines (MC68040)

All references to the MC68000, MC68020, and MC68030 include references to the corresponding embedded controllers, MC68EC000, MC68EC020, and MC68EC030. All references to the MC68040 include the MC68LC040 and MC68EC040. This applies throughout this section unless otherwise specified.

If the instruction applies to all the M68000 family but a processor or processors may use a different instruction field, instruction format, etc., the differences will be identified within the paragraph. For example:

#### MC68020, MC68030 and MC68040 only

| (bd,An,Xn)* 110 reg. number: A | (bd,PC,Xn)* | _ | _ |
|--------------------------------|-------------|---|---|
|--------------------------------|-------------|---|---|

<sup>\*</sup>Can be used with CPU32 processo

The following instructions are listed separately for each processor due to the many differences involved within the instruction:

PFLUSH Flush ATC Entries
PMOVE Move PMMU Register
PTEST Test Logical Address

**Appendix A Processor Instruction Summary** provides a listing of all processors and the instructions that apply to them for quick reference.

ANDI to SR

## AND Immediate to the Status Register (M68000 Family)

ANDI to SR

**Operation:** If Supervisor State

Then Source L SR  $\rightarrow$  SR

**ELSE TRAP** 

**Assembler** 

**Syntax:** ANDI # < data > ,SR

**Attributes:** size = (word)

**Description:** Performs an AND operation of the immediate operand with the contents of the status register and stores the result in the status register. All implemented bits of the status register are affected.

### **Condition Codes:**

| X | Ν | Z | V | С |
|---|---|---|---|---|
| * | * | * | * | * |

X—Cleared if bit 4 of immediate operand is zero; unchanged otherwise.

N—Cleared if bit 3 of immediate operand is zero; unchanged otherwise.

Z—Cleared if bit 2 of immediate operand is zero; unchanged otherwise.

V—Cleared if bit 1 of immediate operand is zero; unchanged otherwise.

C—Cleared if bit 0 of immediate operand is zero; unchanged otherwise.

### **Instruction Format:**

| 5 | 14               | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---|------------------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0 | 0                | 0  | 0  | 0  | 0  | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 0 |
|   | 16-BIT WORD DATA |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

CINV In

## Invalidate Cache Lines (MC68040, MC68LC040)

CINV

**Operation:** If Supervisor State

Then Invalidate Selected Cache Lines

**ELSE TRAP** 

**Assembler** 

**Syntax:** CINVL < caches > ,(An)

CINVP < caches > ,(An)

CINVA < caches >

Where < caches > specifies the instruction cache,

data cache, both caches, or neither cache.

Attributes: Unsized

**Description:** Invalidates selected cache lines. The data cache, instruction cache, both caches, or neither cache can be specified. Any dirty data in data cache lines that invalidate are lost; the CPUSH instruction must be used when dirty data may be contained in the data cache.

### Specific cache lines can be selected in three ways:

- 1. CINVL invalidates the cache line (if any) matching the physical address in the specified address register.
- CINVP invalidates the cache lines (if any) matching the physical memory page in the specified address register. For example, if 4K-byte page sizes are selected and An contains \$12345000, all cache lines matching page \$12345000 invalidate.
- 3. CINVA invalidates all cache entries.

#### Condition Codes:

Not affected.

**CINV** 

## Invalidate Cache Lines (MC68040, MC68LC040)

**CINV** 

### **Instruction Format:**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7   | 6   | 5 | 4   | 3  | 2 | 1       | 0   |
|----|----|----|----|----|----|---|---|-----|-----|---|-----|----|---|---------|-----|
| 1  | 1  | 1  | 1  | 0  | 1  | 0 | 0 | CAC | CHE | 0 | SCC | PE | R | EGISTEI | ~ 1 |

### **Instruction Fields:**

Cache field—Specifies the Cache.

00—No Operation

01—Data Cache

10—Instruction Cache

11—Data and Instruction Caches

Scope field—Specifies the Scope of the Operation.

00—Illegal (causes illegal instruction trap)

01—Line

10—Page

11—All

Register field—Specifies the address register for line and page operations. For line operations, the low-order bits 3–0 of the address are don't cares. Bits 11–0 or 12–0 of the address are don't care for 4K-byte or 8K-byte page operations, respectively.

**cpRESTORE** 

### Coprocessor Restore Functions (MC68020, MC68030)

**cpRESTORE** 

**Operation:** If Supervisor State

Then Restore Internal State of Coprocessor

**ELSE TRAP** 

**Assembler** 

**Syntax:** cpRESTORE < ea >

Attributes: Unsized

**Description:** Restores the internal state of a coprocessor usually after it has been saved by a preceding cpSAVE instruction.

### **Condition Codes:**

Not affected.

### **Instruction Format:**

| 15 | 14 | 13 | 12 | 11  | 10    | 9   | 8 | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0  |
|----|----|----|----|-----|-------|-----|---|---|---|---|------|---------|-------|--------|----|
| 1  | 1  | 1  | 1  | COF | ROCES | SOR | 1 | _ | 1 |   | EFI  | FECTIVE | ADDRE | SS     |    |
| '  | '  | '  | '  |     | ID    |     | ' | " | ' |   | MODE |         | R     | EGISTE | :R |

## cpRESTORE

### Coprocessor Restore Functions (MC68020, MC68030)

## **cpRESTORE**

### **Instruction Fields:**

Coprocessor ID field—Identifies the coprocessor that is to be restored. Coprocessor ID of 000 results in an F-line exception for the MC68030.

Effective Address field—Specifies the location where the internal state of the coprocessor is located. Only postincrement or control addressing modes can be used as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn                      | _    | _              |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| — (An)                  | _    | _              |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn], od)        | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg.number:An  |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | 111  | 100      |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |
| ([bd,PC,Xn], od)        | 111  | 011      |
| ([bd,PC],Xn, od         | 111  | 011      |

### **NOTE**

If the format word returned by the coprocessor indicates "come again", pending interrupts are not serviced.

**cpSAVE** 

## Coprocessor Save Function (MC68020, MC68030)

**cpSAVE** 

**Operation:** If Supervisor State

Then Save Internal State of Coprocessor

**ELSE TRAP** 

**Assembler** 

**Syntax:** cpSAVE < ea >

Attributes: Unsized

**Description:** Saves the internal state of a coprocessor in a format that can be restored by a cpRESTORE instruction.

**Condition Codes:** 

Not affected.

### **Instruction Format:**

|  | 15 | 14 | 13 | 12 | 11  | 10    | 9   | 8 | 7 | 6 | 5 | 4    | 3       | 2             | 1      | 0 |
|--|----|----|----|----|-----|-------|-----|---|---|---|---|------|---------|---------------|--------|---|
|  | 1  |    | 1  | 1  | COP | ROCES | SOR | 1 |   |   |   | EFI  | FECTIVE | CTIVE ADDRESS |        |   |
|  |    | '  | '  | '  |     | ID    |     | ' | U | U |   | MODE |         | R             | EGISTE | R |

### **Instruction Fields:**

Coprocessor ID field—Identifies the coprocessor for this operation. Coprocessor ID of 000 results in an F-line exception for the MC68030.

Effective Address field—Specifies the location where the internal state of the coprocessor is to be saved. Only predecrement or control alterable addressing modes can be used as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn                      | _    | _              |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | _    | _              |
| — (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn], od)        | 110  | reg. number:An |
| ([bd,An],Xn, od)        | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | _    | _        |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | _    | _        |
| (d <sub>8</sub> ,PC,Xn) | _    | _        |
| (bd,PC,Xn)              | _    | _        |
| ([bd,PC,Xn],od)         | _    | _        |
| ([bd,PC],Xn, od)        | _    | _        |

**CPUSH** 

## Push and Invalidate Cache Lines (MC68040, MC68LC040)

**CPUSH** 

**Operation:** If Supervisor State

Then If Data Cache

Then Push Selected Dirty Data Cache Lines

Invalidate Selected Cache Lines

**ELSE TRAP** 

Assembler

Syntax:

CPUSHL < caches > ,(An) CPUSHP < caches > ,(An)

CPUSHA < caches >

Where < caches > specifies the instruction cache, data cache,

both caches, or neither cache.

Attributes: Unsized

**Description:** Pushes and then invalidates selected cache lines. The DATA cache, instruction cache, both caches, or neither cache can be specified. When the data cache is specified, the selected data cache lines are first pushed to memory (if they contain dirty DATA) and then invalidated. Selected instruction cache lines are invalidated.

Specific cache lines can be selected in three ways:

- 1. CPUSHL pushes and invalidates the cache line (if any) matching the physical address in the specified address register.
- 2. CPUSHP pushes and invalidates the cache lines (if any) matching the physical memory page in the specified address register. For example, if 4K-byte page sizes are selected and An contains \$12345000, all cache lines matching page \$12345000 are selected.
- 3. CPUSHA pushes and invalidates all cache entries.

#### **Condition Codes:**

Not affected.

### **Instruction Format:**

|   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6   | 5 | 4   | 3   | 2 | 1      | 0 |
|---|----|----|----|----|----|----|---|---|---|-----|---|-----|-----|---|--------|---|
| ſ | 1  | 1  | 1  | 1  | 0  | 1  | 0 | 0 |   | CHE | 1 | SCC | OPE | R | EGISTE | R |

### **CPUSH**

## Push and Invalidate Cache Lines (MC68040, MC68LC040)

### **CPUSH**

### **Instruction Fields:**

Cache field—Specifies the Cache.

00-No Operation

01—Data Cache

10—Instruction Cache

11—Data and Instruction Caches

Scope field—Specifies the Scope of the Operation.

00—Illegal (causes illegal instruction trap)

01—Line

10—Page

11—AII

Register field—Specifies the address register for line and page operations. For line operations, the low-order bits 3–0 of the address are don't care. Bits 11–0 or 12–0 of the address are don't care for 4K-byte or 8K-byte page operations, respectively.

## EORI to SR

## Exclusive-OR Immediate to the Status Register (M68000 Family)



**Operation:** If Supervisor State

Then Source  $\oplus$  SR  $\rightarrow$  SR

**ELSE TRAP** 

**Assembler** 

**Syntax:** EORI # < data > ,SR

**Attributes:** Size = (Word)

**Description:** Performs an exclusive-OR operation on the contents of the status register using the immediate operand and stores the result in the status register. All implemented bits of the status register are affected.

#### **Condition Codes:**

| X | Ν | Z | V | С |
|---|---|---|---|---|
| * | * | * | * | * |

X—Changed if bit 4 of immediate operand is one; unchanged otherwise.

N—Changed if bit 3 of immediate operand is one; unchanged otherwise.

Z—Changed if bit 2 of immediate operand is one; unchanged otherwise.

V—Changed if bit 1 of immediate operand is one; unchanged otherwise.

C—Changed if bit 0 of immediate operand is one; unchanged otherwise.

### **Instruction Format:**

| 15 | 14               | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|------------------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0  | 0                | 0  | 0  | 1  | 0  | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 0 |
|    | 16-BIT WORD DATA |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

### **FRESTORE**

## Restore Internal Floating-Point State

**FRESTORE** 

(MC68881, MC68882, MC68040 only)

**Operation:** If in Supervisor State

Then FPU State Frame → Internal State

**ELSE TRAP** 

**Assembler** 

**Syntax:** FRESTORE < ea >

Attributes: Unsized

**Description:** Aborts the execution of any floating-point operation in progress and loads a new floating-point unit internal state from the state frame located at the effective address. The first word at the specified address is the format word of the state frame. It specifies the size of the frame and the revision number of the floating-point unit that created it. A format word is invalid if it does not recognize the size of the frame or the revision number does not match the revision of the floating-point unit. If the format word is invalid, FRESTORE aborts, and a format exception is generated. If the format word is valid, the appropriate state frame is loaded, starting at the specified location and proceeding through higher addresses.

The FRESTORE instruction does not normally affect the programmer's model registers of the floating-point coprocessor, except for the NULL state size, as described below. It is only for restoring the user invisible portion of the machine. The FRESTORE instruction is used with the FMOVEM instruction to perform a full context restoration of the floating-point unit, including the floating-point data registers and system control registers. To accomplish a complete restoration, the FMOVEM instructions are first executed to load the programmer's model, followed by the FRESTORE instruction to load the internal state and continue any previously suspended operation.

### **FRESTORE**

### Restore Internal Floating-Point State (MC68881, MC68882, MC68040 only)

**FRESTORE** 

The current implementation supports the following four state frames:

**NULL**:

This state frame is 4 bytes long, with a format word of \$0000. An FRE-STORE operation with this size state frame is equivalent to a hardware reset of the floating-point unit. The programmer's model is set to the reset state, with nonsignaling NANs in the floating-point data registers and zeros in the floating-point control register, floating-point status register, and floating-point instruction address register. (Thus, it is unnecessary to load the programmer's model before this operation.)

IDLE:

This state frame is 4 bytes long in the MC68040, 28 (\$1C) bytes long in the MC68881, and 60 (\$3C) bytes long in the MC68882. An FRESTORE operation with this state frame causes the floating-point unit to be restored to the idle state, waiting for the initiation of the next instruction, with no exceptions pending. The programmer's model is not affected by loading this type of state frame.

UNIMP:

This state frame is generated only by the MC68040. It is 48 (\$30) bytes long. An FSAVE that generates this size frame indicates either an unimplemented floating-point instruction or only an E1 exception is pending. This frame is never generated when an unsupported data type exception is pending or an E3 exception is pending. If both E1 and E3 exceptions are pending, a BUSY frame is generated.

BUSY:

This state frame is 96 (\$60) bytes long in the MC68040, 184 (\$B8) bytes long in the MC68881, and 216 (\$D8) bytes long in the MC68882. An FRESTORE operation with this size state frame causes the floating-point unit to be restored to the busy state, executing the instructions that were suspended by a previous FSAVE operation. The programmer's model is not affected by loading this type of state frame; however, the completion of the suspended instructions after the restore is executed may modify the programmer's model.

Floating-Point Status Register: Cleared if the state size is NULL; otherwise, not affected.

## **FRESTORE**

### Restore Internal Floating-Point State (MC68881, MC68882, MC68040 only)

### **FRESTORE**

### **Instruction Format:**

| 15 | 14 | 13 | 12          | 11  | 10 | 9   | 8 | 7                | 6 | 5 | 4      | 3 | 2 | 1 | 0 |
|----|----|----|-------------|-----|----|-----|---|------------------|---|---|--------|---|---|---|---|
| 1  | 1  | 1  | COPROCESSOR | SOR |    | 0 4 |   | EFFECTIVE ADDRES |   |   |        |   |   |   |   |
| '  | '  |    |             | '   | "  | '   |   | MODE             |   | R | EGISTE | R |   |   |   |

### **Instruction Field:**

Effective Address field—Determines the addressing mode for the state frame. Only postincrement or control addressing modes can be used as listed in the following table:

| Addressing Mode         | Mode | Register       | Addressing Mode         | Mode | Register |
|-------------------------|------|----------------|-------------------------|------|----------|
| Dn                      | _    | _              | (xxx).W                 | 111  | 000      |
| An                      | _    | _              | (xxx).L                 | 111  | 001      |
| (An)                    | 010  | reg. number:An | # < data >              | _    | _        |
| (An) +                  | 011  | reg. number:An |                         |      |          |
| —(An)                   | _    | _              |                         |      |          |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An | (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An | (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,An,Xn)              | 110  | reg. number:An | (bd,PC,Xn)              | 111  | 011      |
| ([bd,An,Xn], od)        | 110  | reg. number:An | ([bd,PC,Xn], od)        | 111  | 011      |
| ([bd,An],Xn, od)        | 110  | reg. number:An | ([bd,PC],Xn, od)        | 111  | 011      |

FSAVE Save Internal Floating-Point State (MC68881, MC68882, MC68040 only)

**FSAVE** 

**Operation:** If in Supervisor State

Then FPU Internal State → State Frame

**ELSE TRAP** 

**Assembler** 

Syntax: FSAVE < ea >

Attributes: Unsized

**Description:** FSAVE allows the completion of any floating-point operation in progress for the MC68040. It saves the internal state of the floating-point unit in a state frame located at the effective address. After the save operation, the floating-point unit is in the idle state, waiting for the execution of the next instruction. The first word written to the state frame is the format word specifying the size of the frame and the revision number of the floating-point unit.

Any floating-point operations in progress when an FSAVE instruction is encountered can be completed before the FSAVE executes, saving an IDLE state frame. Execution of instructions already in the floating-point unit pipeline continues until completion of all instructions in the pipeline or generation of an exception by one of the instructions. An IDLE state frame is created by the FSAVE if no exceptions occurred; otherwise, a BUSY or an UNIMP stack frame is created.

FSAVE suspends the execution of any operation in progress and saves the internal state in a state frame located at the effective address for the MC68881/MC68882. After the save operation, the floating-point coprocessor is in the idle state, waiting for the execution of the next instruction. The first word written to the state frame is the format word, specifying the size of the frame and the revision number of the floating-point coprocessor. The microprocessor unit initiates the FSAVE instruction by reading the floating-point coprocessor save CIR. The floating-point coprocessor save CIR is encoded with a format word that indicates the appropriate action to be taken by the main processor. The current implementation of the floating-point coprocessor always returns one of five responses in the save CIR:

| Value  | Definition                     |
|--------|--------------------------------|
| \$0018 | Save NULL state frame          |
| \$0118 | Not ready, come again          |
| \$0218 | Illegal, take format exception |
| \$XX18 | Save IDLE state frame          |
| \$XXB4 | Save BUSY state frame          |

NOTE: XX is the floating-point coprocessor version number.

### **FSAVE**

## Save Internal Floating-Point State (MC68881, MC68882, MC68040 only)

**FSAVE** 

The not ready format word indicates that the floating-point coprocessor is not prepared to perform a state save and that the microprocessor unit should process interrupts, if necessary, and re-read the save CIR. The floating-point coprocessor uses this format word to cause the main processor to wait while an internal operation completes, if possible, to allow an IDLE frame rather than a BUSY frame to be saved. The illegal format word aborts an FSAVE instruction that is attempted while the floating-point coprocessor executes a previous FSAVE instruction. All other format words cause the microprocessor unit to save the indicated state frame at the specified address. For state frame details see state frames in the appropriate user's manual.

The following state frames apply to both the MC68040 and the MC68881/MC68882.

NULL: This state frame is 4 bytes long. An FSAVE instruction that generates this state frame indicates that the floating-point unit state has not been modified since the last hardware reset or FRESTORE instruction with a NULL state frame. This indicates that the programmer's model is in the reset state, with nonsignaling NANs in the floating-point data registers and zeros in the floating-point control register, floating-point status register, and floating-point instruction address register. (Thus, it is not necessary to save the programmer's model.)

IDLE: This state frame is 4 bytes long in the MC68040, 28 (\$1C) bytes long in the MC68881, and 60 (\$3C) bytes long in the MC68882. An FSAVE instruction that generates this state frame indicates that the floating-point unit finished in an idle condition and is without any pending exceptions waiting for the initiation of the next instruction.

UNIMP: This state frame is generated only by the MC68040. It is 48 (\$30) bytes long. An FSAVE that generates this size frame indicates either an unimplemented floating-point instruction or that only an E1 exception is pending. This frame is never generated when an unsupported data type exception or an E3 exception is pending. If both E1 and E3 exceptions are pending, a BUSY frame is generated.

BUSY: This state frame is 96 (\$60) bytes long in the MC68040, 184 (\$B8) bytes long in the MC68881, and 216 (\$D8) bytes long in the MC68882. An FSAVE instruction that generates this size state frame indicates that the floating-point unit encountered an exception while attempting to complete the execution of the previous floating-point instructions.

### **FSAVE**

## Save Internal Floating-Point State (MC68881, MC68882, MC68040 only)

**FSAVE** 

The FSAVE does not save the programmer's model registers of the floating-point unit; it saves only the user invisible portion of the machine. The FSAVE instruction may be used with the FMOVEM instruction to perform a full context save of the floating-point unit that includes the floating-point data registers and system control registers. To accomplish a complete context save, first execute an FSAVE instruction to suspend the current operation and save the internal state, then execute the appropriate FMOVEM instructions to store the programmer's model.

Floating-Point Status Register: Not affected.

#### **Instruction Format:**

| 15 | 14 | 13             | 12   | 11          | 10 | 9   | 8 | 7    | 6 | 5                 | 4      | 3 | 2 | 1 | 0 |
|----|----|----------------|------|-------------|----|-----|---|------|---|-------------------|--------|---|---|---|---|
| 1  | 1  | 1              | 1    | COPROCESSOR |    | SOR | 1 | _    |   | EFFECTIVE ADDRESS |        |   |   |   |   |
| '  | '  | 1   1   1   ID | 1 ID | '           | "  | 0   |   | MODE |   | R                 | EGISTE | R |   |   |   |

### **Instruction Field:**

Effective Address field—Determines the addressing mode for the state frame. Only predecrement or control alterable addressing modes can be used as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn                      | _    | _              |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | _    | _              |
| —(An)                   | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn] ,od)        | 110  | reg. number:An |
| ([bd,An],Xn ,od)        | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | _    |          |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | _    | 1        |
| (d <sub>8</sub> ,PC,Xn) | _    |          |
| (bd,PC,Xn)              | -    | 1        |
| ([bd,PC,Xn] ,od)        | _    | _        |
| ([bd,PC],Xn ,od)        | _    |          |

# MOVE from SR

# MOVE from SR

Move from the Status Register (MC68EC000, MC68010, MC68020, MC68030, MC68040, CPU32)

**Operation:** If Supervisor State

Then SR → Destination

Else TRAP

**Assembler** 

**Syntax:** MOVE SR, < ea >

**Attributes:** Size = (Word)

**Description:** Moves the data in the status register to the destination location. The destination is word length. Unimplemented bits are read as zeros.

### **Condition Codes:**

Not affected.

### **Instruction Format:**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5                 | 4 | 3 | 2 | 1      | 0 |
|----|----|----|----|----|----|---|---|---|---|-------------------|---|---|---|--------|---|
| 0  | 1  | _  |    | _  |    |   |   | 1 | 4 | EFFECTIVE ADDRESS |   |   |   |        |   |
| 0  | '  | "  | "  | "  | "  | " | " | ' | ' | MODE              |   |   | R | EGISTE | R |

# MOVE from SR

# MOVE from SR

### Move from the Status Register (MC68EC000, MC68010, MC68020, MC68030, MC68040, CPU32)

### **Instruction Field:**

Effective Address field—Specifies the destination location. Only data alterable addressing modes can be used as listed in the following tables:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn                      | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| —(An)                   | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | _    | _        |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | _    | _        |
| (d <sub>8</sub> ,PC,Xn) | _    | _        |

### MC68020, MC68030, and MC68040 only

| (bd,An,Xn)*      | 110 | reg. number:An |
|------------------|-----|----------------|
| ([bd,An,Xn] ,od) | 110 | reg. number:An |
| ([bd,An],Xn ,od) | 110 | reg. number:An |

| (bd,PC,Xn)*      | _ | _ |
|------------------|---|---|
| ([bd,PC,Xn] ,od) | _ |   |
| ([bd,PC],Xn ,od) | _ | _ |

### **NOTE**

Use the MOVE from CCR instruction to access only the condition codes.

<sup>\*</sup>Available for the CPU32.

MOVE to SR

### Move to the Status Register (M68000 Family)

MOVE to SR

**Operation:** If Supervisor State

Then Source  $\rightarrow$  SR

Else TRAP

Assembler

**Syntax:** MOVE < ea > ,SR

**Attributes:** Size = (Word)

**Description:** Moves the data in the source operand to the status register. The source operand is a word, and all implemented bits of the status register are affected.

### **Condition Codes:**

Set according to the source operand.

### **Instruction Format:**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0  |
|----|----|----|----|----|----|---|---|---|---|---|------|---------|-------|--------|----|
| 0  | 1  | 0  |    | 0  | 1  | 1 | _ | 1 | 1 |   | EFI  | FECTIVE | ADDRE | SS     |    |
| U  | '  | 0  | "  | 0  | '  | ' | " | ' | ' |   | MODE |         | R     | EGISTE | :R |

MOVE to SR

## Move to the Status Register (M68000 Family)

### MOVE to SR

### **Instruction Field:**

Effective Address field—Specifies the location of the source operand. Only data addressing modes can be used as listed in the following tables:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn                      | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| —(An)                   | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | 111  | 100      |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |

### MC68020, MC68030, and MC68040 only

| (bd,An,Xn)*      | 110 | reg. number:An |
|------------------|-----|----------------|
| ([bd,An,Xn] ,od) | 110 | reg. number:An |
| ([bd,An],Xn ,od) | 110 | reg. number:An |

| (bd,PC,Xn)*      | 111 | 011 |
|------------------|-----|-----|
| ([bd,PC,Xn] ,od) | 111 | 011 |
| ([bd,PC],Xn ,od) | 111 | 011 |

<sup>\*</sup>Available for the CPU32.

MOVE USP

### Move User Stack Pointer (M68000 Family)

MOVE USP

**Operation:** If Supervisor State

Then USP  $\rightarrow$  An or An  $\rightarrow$  USP

Else TRAP

**Assembler** MOVE USP,An **Syntax:** MOVE An,USP

**Attributes:** Size = (Long)

**Description:** Moves the contents of the user stack pointer to or from the specified address register.

### **Condition Codes:**

Not affected.

### **Instruction Format:**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3  | 2 | 1      | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|----|---|--------|---|
| 0  | 1  | 0  | 0  | 1  | 1  | 1 | 0 | 0 | 1 | 1 | 0 | dr | R | EGISTE | R |

### **Instruction Fields:**

dr field—Specifies the direction of transfer.

0—Transfer the address register to the user stack pointer.

1—Transfer the user stack pointer to the address register.

Register field—Specifies the address register for the operation.

**MOVEC** 

### Move Control Register

MOVEC

(MC68010, MC68020, MC68030, MC68040, CPU32)

**Operation:** If Supervisor State

Then  $Rc \rightarrow Rn$  or  $Rn \rightarrow Rc$ 

Else TRAP

**Assembler** MOVEC Rc,Rn **Syntax:** MOVEC Rn,Rc

**Attributes:** Size = (Long)

**Description:** Moves the contents of the specified control register (Rc) to the specified general register (Rn) or copies the contents of the specified general register to the specified control register. This is always a 32-bit transfer, even though the control register may be implemented with fewer bits. Unimplemented bits are read as zeros.

### **Condition Codes:**

Not affected.

#### **Instruction Format:**

| 15  | 14 | 13      | 12  | 11 | 10 | 9 | 8 | 7  | 6     | 5      | 4  | 3 | 2 | 1 | 0  |
|-----|----|---------|-----|----|----|---|---|----|-------|--------|----|---|---|---|----|
| 0   | 1  | 0       | 0   | 1  | 1  | 1 | 0 | 0  | 1     | 1      | 1  | 1 | 0 | 1 | dr |
| A/D | F  | REGISTE | .11 |    |    |   |   | CC | NTROL | REGIST | ER |   |   |   |    |

#### **Instruction Fields:**

dr field—Specifies the direction of the transfer.

- 0—Control register to general register.
- 1—General register to control register.

A/D field—Specifies the type of general register.

- 0—Data Register
- 1—Address Rregister

### **MOVEC**

### Move Control Register (MC68010, MC68020, MC68030, MC68040, CPU32)

**MOVEC** 

Register field—Specifies the register number.

Control Register field—Specifies the control register.

| Hex <sup>1</sup> | Control Register                                      |
|------------------|-------------------------------------------------------|
| MC               | 68010/MC68020/MC68030/MC68040/CPU32                   |
| 000              | Source Function Code (SFC)                            |
| 001              | Destination Function Code (DFC)                       |
| 800              | User Stack Pointer (USP)                              |
| 801              | Vector Base Register (VBR)                            |
|                  | MC68020/MC68030/MC68040                               |
| 002              | Cache Control Register (CACR)                         |
| 802              | Cache Address Register (CAAR) <sup>2</sup>            |
| 803              | Master Stack Pointer (MSP)                            |
| 804              | Interrupt Stack Pointer (ISP)                         |
|                  | MC68040/MC68LC040                                     |
| 003              | MMU Translation Control Register (TC)                 |
| 004              | Instruction Transparent Translation Register 0 (ITT0) |
| 005              | Instruction Transparent Translation Register 1 (ITT1) |
| 006              | Data Transparent Translation Register 0 (DTT0)        |
| 007              | Data Transparent Translation Register 1 (DTT1)        |
| 805              | MMU Status Register (MMUSR)                           |
| 806              | User Root Pointer (URP)                               |
| 807              | Supervisor Root Pointer (SRP)                         |
|                  | MC68EC040 only                                        |
| 004              | Instruction Access Control Register 0 (IACR0)         |
| 005              | Instruction Access Control Register 1 (IACR1)         |
| 006              | Data Access Control Register 0 (DACR1)                |
| 007              | Data Access Control Register 1 (DACR1)                |

### NOTES:

- 1. Any other code causes an illegal instruction exception
- 2. For the MC68020 and MC68030 only.

**MOVES** 

### Move Address Space

**MOVES** 

(MC68010, MC68020, MC68030, MC68040, CPU32)

**Operation:** If Supervisor State

Then  $Rn \rightarrow Destination [DFC]$  or Source [SFC]  $\rightarrow Rn$ 

Else TRAP

Assembler MOVES Rn, < ea > Syntax: MOVES < ea > ,Rn

**Attributes:** Size = (Byte, Word, Long)

**Description:** This instruction moves the byte, word, or long operand from the specified general register to a location within the address space specified by the destination function code (DFC) register, or it moves the byte, word, or long operand from a location within the address space specified by the source function code (SFC) register to the specified general register. If the destination is a data register, the source operand replaces the corresponding low-order bits of that data register, depending on the size of the operation. If the destination is an address register, the source operand is sign-extended to 32 bits and then loaded into that address register.

### **Condition Codes:**

Not affected.

#### **Instruction Format:**

| 15  | 14 | 13     | 12 | 11 | 10 | 9 | 8 | 7   | 6        | 5 | 4    | 3       | 2     | 1      | 0 |
|-----|----|--------|----|----|----|---|---|-----|----------|---|------|---------|-------|--------|---|
| 0   |    | _      | _  | 1  | 1  | 1 | _ | CI. | ZE       |   | EF   | FECTIVE | ADDRE | SS     |   |
| U   | "  | "      | "  | '  | '  | ' | " | 31. | <b>4</b> |   | MODE |         | R     | EGISTE | R |
| A/D | R  | EGISTE | R  | dr | 0  | 0 | 0 | 0   | 0        | 0 | 0    | 0       | 0     | 0      | 0 |

**MOVES** 

### **MOVES**

## Move Address Space (MC68010, MC68020, MC68030, MC68040, CPU32)

#### Instruction Fields:

Size field—Specifies the size of the operation.

00—Byte Operation

01—Word Operation

10—Long Operation

Effective Address field—Specifies the source or destination location within the alternate address space. Only memory alterable addressing modes can be used as listed in the following tables:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn                      | _    | _              |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| —(An)                   | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | _    | _        |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | _    | _        |
| (d <sub>8</sub> ,PC,Xn) | _    | _        |

#### MC68020, MC68030, and MC68040 only

| (bd,An,Xn)*      | 110 | reg. number:An |
|------------------|-----|----------------|
| ([bd,An,Xn] ,od) | 110 | reg. number:An |
| ([bd,An],Xn ,od) | 110 | reg. number:An |

| (bd,PC,Xn)*      | _ | _ |
|------------------|---|---|
| ([bd,PC,Xn],od)  | _ | _ |
| ([bd,PC],Xn ,od) | _ | _ |

A/D field—Specifies the type of general register.

0—Data Register

1—Address Register

Register field—Specifies the register number.

dr field—Specifies the direction of the transfer.

0—From < ea > to general register.

1—From general register to < ea > .

<sup>\*</sup>Available for the CPU32.

### **MOVES**

### Move Address Space (MC68010, MC68020, MC68030, MC68040, CPU32)

### **MOVES**

#### NOTE

The value stored is undefined for either of the two following examples with the same address register as both source and destination.

MOVES.x An,(An) + MOVES.x An,D(An)

The current implementations of the MC68010, MC68020, MC68030, and MC68040 store the incremented or decremented value of An. Check the following code sequence to determine what value is stored for each case.

MOVEA.L #\$1000,A0 MOVES.L A0,(A0) + MOVES.L A0,D(A0)

Because the MC68040 implements a merged instruction and data space, the MC68040's integer unit into data references (SFC/DFC = 5 or 1) translates MOVES accesses to the OinstructionO address spaces (SFC/DFC = 6 or 2). The data memory unit handles these translated accesses as normal data accesses. If the access fails due to an ATC fault or a physical bus error, the resulting access error stack frame contains the converted function code in the TM field for the faulted access. To maintain cache coherency, MOVES accesses to write the OinstructionO address space must be preceded by invalidation of the instruction cache line containing the referenced location.

ORI to SR

## Inclusive-OR Immediate to the Status Register (M68000 Family)

ORI to SR

**Operation:** If Supervisor State

Then Source V SR → SR

Else TRAP

**Assembler** 

**Syntax:** ORI  $\# < \text{data} > \ , SR$ 

**Attributes:** Size = (Word)

**Description:** Performs an inclusive-OR operation of the immediate operand and the status register's contents and stores the result in the status register. All implemented bits of the status register are affected.

#### **Condition Codes:**

| X | Ν | Z | V | С |
|---|---|---|---|---|
| * | * | * | * | * |

X—Set if bit 4 of immediate operand is one; unchanged otherwise.

N—Set if bit 3 of immediate operand is one; unchanged otherwise.

Z—Set if bit 2 of immediate operand is one; unchanged otherwise.

V—Set if bit 1 of immediate operand is one; unchanged otherwise.

C—Set if bit 0 of immediate operand is one; unchanged otherwise.

### **Instruction Format:**

| 15 | 14               | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|------------------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0  | 0                | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 0 |
|    | 16—BIT WORD DATA |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**PBcc** 

## Branch on PMMU Condition (MC68851)

**PBcc** 

**Operation:** If Supervisor State

Then If cc True

Then (PC) +  $dn \rightarrow PC$ 

Else TRAP

**Assembler** 

**Syntax:** PBcc. < size > < label >

**Attributes:** Size = (Word, Long)

**Description:** If the specified paged memory management unit condition is met, execution continues at location (PC) + displacement. The displacement is a twos complement integer that counts the relative distance in bytes. The value in the program counter is the address of the displacement word(s). The displacement may be either 16 or 32 bits.

The condition specifier cc indicates the following conditions:

| Specifier | Description | Condition Field |
|-----------|-------------|-----------------|
| BS        | B set       | 000000          |
| LS        | L set       | 000010          |
| SS        | S set       | 000100          |
| AS        | A set       | 000110          |
| WS        | W set       | 001000          |
| IS        | I set       | 001010          |
| GS        | G set       | 001100          |
| CS        | C set       | 001110          |

| Specifier | Description | Condition Field |  |  |  |
|-----------|-------------|-----------------|--|--|--|
| ВС        | B clear     | 000001          |  |  |  |
| LC        | L clear     | 000011          |  |  |  |
| SC        | S clear     | 000101          |  |  |  |
| AC        | A clear     | 000111          |  |  |  |
| WC        | W clear     | 001001          |  |  |  |
| IC        | I clear     | 001011          |  |  |  |
| GC        | G clear     | 001101          |  |  |  |
| CC        | C clear     | 001111          |  |  |  |

**PMMU Status Register:** Not affected.

### **Instruction Format:**

| 15 | 14                                                                 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6    | 5 | 4  | 3       | 2       | 1  | 0 |
|----|--------------------------------------------------------------------|----|----|----|----|---|---|---|------|---|----|---------|---------|----|---|
| 1  | 1                                                                  | 1  | 1  | 0  | 0  | 0 | 0 | 1 | SIZE |   | MC | 68851 C | CONDITI | ON |   |
|    | 16-BIT DISPLACEMENT OR MOST SIGNIFICANT WORD OF 32-BITDISPLACEMENT |    |    |    |    |   |   |   |      |   |    |         |         |    |   |
|    | LEAST SIGNIFICANT WORD OF 32-BIT DISPLACEMENT (IF NEEDED)          |    |    |    |    |   |   |   |      |   |    |         |         |    |   |

### **PBcc**

## Branch on PMMU Condition (MC68851)

**PBcc** 

### **Instruction Fields:**

Size field—Specifies the size of the displacement.

- 0—Displacement is 16 bits.
- 1—Displacement is 32 bits.
- MC68851 Condition field—Specifies the coprocessor condition to be tested. This field is passed to the MC68851, which provides directives to the main processor for processing this instruction.
- Word Displacement field—The shortest displacement form for MC68851 branches is 16 bits.

Long-Word Displacement field—Allows a displacement larger than 16 bits.

PDBCC Test, Decrement, and Branch (MC68851)

**PDBcc** 

**Operation:** If Supervisor State

Then If cc False

Then (DnD1  $\rightarrow$  Dn; If Dn < > D1 then (PC) + d 3 PC)

Else No Operation

Else TRAP

**Assembler** 

Syntax: PDBcc Dn, < label >

**Attributes:** Size = (Word)

**Description:** This instruction is a looping primitive of three parameters: an MC68851 condition, a counter (an MC68020 data register), and a 16-bit displacement. The instruction first tests the condition to determine if the termination condition for the loop has been met. If so, the main processor executes the next instruction in the instruction stream. If the termination condition is not true, the low-order 16 bits of the counter register are decremented by one. If the result is not D1, execution continues at the location specified by the current value of the program counter plus the sign-extended 16-bit displacement. The value of the program counter used in the branch address calculation is the address of the PDBcc instruction plus two.

The condition specifier cc indicates the following conditions:

| Specifier | Description | Condition Field |  |  |
|-----------|-------------|-----------------|--|--|
| BS        | B set       | 000000          |  |  |
| LS        | L set       | 000010          |  |  |
| SS        | S set       | 000100          |  |  |
| AS        | A set       | 000110          |  |  |
| WS        | W set       | 001000          |  |  |
| IS        | I set       | 001010          |  |  |
| GS        | G set       | 001100          |  |  |
| CS        | C set       | 001110          |  |  |

| Specifier | Description | <b>Condition Field</b> |
|-----------|-------------|------------------------|
| ВС        | B clear     | 000001                 |
| LC        | L clear     | 000011                 |
| SC        | S clear     | 000101                 |
| AC        | A clear     | 000111                 |
| WC        | W clear     | 001001                 |
| IC        | I clear     | 001011                 |
| GC        | G clear     | 001101                 |
| CC        | C clear     | 001111                 |

### **PDBcc**

### Test, Decrement, and Branch (MC68851)

**PDBcc** 

PMMU Status Register: Not affected.

#### **Instruction Format:**

| 15 | 14                  | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5                 | 4 | 3 | 2    | 1       | 0    |  |
|----|---------------------|----|----|----|----|---|---|---|---|-------------------|---|---|------|---------|------|--|
| 1  | 1                   | 1  | 1  | 0  | 0  | 0 | 0 | 0 | 1 | 0                 | 0 | 1 | COUN | IT REGI | STER |  |
| 0  | 0                   | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | MC68851 CONDITION |   |   |      |         |      |  |
|    | 16-BIT DISPLACEMENT |    |    |    |    |   |   |   |   |                   |   |   |      |         |      |  |

### Instruction Fields:

Register field—Specifies the data register in the main processor to be used as the counter.

MC68851 Condition field—Specifies the MC68851 condition to be tested. This field is passed to the MC68851, which provides directives to the main processor for processing this instruction.

Displacement field—Specifies the distance of the branch in bytes.

## Flush Entry in the ATC (MC68030 only)

**PFLUSH** 

**Operation:** If Supervisor State

Then Invalidate ATC Entries for Destination Addresses

Else TRAP

**Assembler** PFLUSHA

**Syntax:** PFLUSH FC,MASK

PFLUSH FC, MASK, < ea >

Attributes: Unsized

**Description:** PFLUSH invalidates address translation cache entries. The instruction has three forms. The PFLUSHA instruction invalidates all entries. When the instruction specifies a function code and mask, the instruction invalidates all entries for a selected function code(s). When the instruction also specifies an < ea > , the instruction invalidates the page descriptor for that effective address entry in each selected function code.

The mask operand contains three bits that correspond to the three function code bits. Each bit in the mask that is set to one indicates that the corresponding bit of the FC operand applies to the operation. Each bit in the mask that is zero indicates a bit of FC and of the ignored function code. For example, a mask operand of 100 causes the instruction to consider only the most significant bit of the FC operand. If the FC operand is 001, function codes 000, 001, 010, and 011 are selected.

The FC operand is specified in one of the following ways:

- 1. Immediate—Three bits in the command word.
- 2. Data Register—The three least significant bits of the data register specified in the instruction.
- 3. Source Function Code (SFC) Register
- 4. Destination Function Code (DFC) Register

### **Condition Codes:**

Not affected.

### **MMU Status Register:**

Not affected.

## Flush Entry in the ATC (MC68030 only)

### **PFLUSH**

#### **Instruction Format:**

| 15 | 14 | 13 | 12   | 11 | 10  | 9 | 8 | 7    | 6 | 5                 | 4 | 3  | 2 | 1    | 0 |   |        |   |
|----|----|----|------|----|-----|---|---|------|---|-------------------|---|----|---|------|---|---|--------|---|
| 1  | 1  | 1  | 1    | 0  | 0   | 0 | 0 | 0    | 0 | EFFECTIVE ADDRESS |   |    |   |      |   |   |        |   |
| 1  | '  | '  | _'   | '  | ' ' |   | " |      | " | "                 | " | "  |   | MODE |   | F | EGISTE | R |
| 0  | 0  | 1  | MODE |    | 0   | 0 |   | MASK |   |                   |   | FC |   |      |   |   |        |   |

#### Instruction Fields:

Effective Address field—Specifies a control alterable address. The address translation cache entry for this address is invalidated. Valid addressing modes are in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn                      | _    | _              |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | _    | _              |
| —(An)                   | _    | _              |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn] ,od)        | 110  | reg. number:An |
| ([bd,An],Xn ,od)        | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | _    |          |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | _    | _        |
| (d <sub>8</sub> ,PC,Xn) | _    | _        |
| (bd,PC,Xn)              |      | _        |
| ([bd,PC,Xn],od)         | _    |          |
| ([bd,PC],Xn ,od)        | _    | _        |

#### **NOTE**

The address field must provide the memory management unit with the effective address to be flushed from the address translation cache, not the effective address describing where the PFLUSH operand is located. For example, to flush the address translation cache entry corresponding to a logical address that is temporarily stored on top of the system stack, the instruction PFLUSH [(SP)] must be used since PFLUSH (SP) would invalidate the address translation cache entry mapping the system stack (i.e., the effective address passed to the memory management unit is the effective address of the system stack, not the effective address formed by the operand located on the top of the stack).

## Flush Entry in the ATC (MC68030 only)

**PFLUSH** 

Mode field—Specifies the type of flush operation.

001—Flush all entries.

100—Flush by function code only.

110—Flush by function code and effective address.

Mask field—Mask for selecting function codes. Ones in the mask correspond to applicable bits; zeros are bits to be ignored. When mode is 001, mask must be 000.

FC field—Function code of entries to be flushed. If the mode field is 001, FC field must be 00000; otherwise:

10XXX — Function code is specified as bits XXX.

01DDD — Function code is specified as bits 2–0 of data register DDD.

00000 — Function code is specified as SFC register.

00001 — Function code is specified as DFC register.

Flush ATC Entries (MC68040, MC68LC040)

**PFLUSH** 

**Operation:** If Supervisor State

Then Invalidate Instruction and Data ATC Entries for Destination

Address Else TRAP

Assembler PFLUSH (An)
Syntax: PFLUSHN (An)
Syntax: PFLUSHA
Syntax: PFLUSHAN

Attributes: Unsized

**Description:** Invalidates address translation cache entries in both the instruction and data address translation caches. The instruction has two forms. The PFLUSHA instruction invalidates all entries. The PFLUSH (An) instruction invalidates the entry in each address translation cache which matches the logical address in An and the specified function code.

The function code for PFLUSH is specified in the destination function code register. Destination function code values of 1 or 2 will result in flushing of user address translation cache entries in both address translation caches; whereas, values of 5 or 6 will result in flushing of supervisor address translation cache entries. PFLUSH is undefined for destination function code values of 0, 3, 4, and 7 and may cause flushing of an unexpected entry.

The PFLUSHN and PFLUSHAN instructions have a global option specified and invalidate only nonglobal entries. For example, if only page descriptors for operating system code have the global bit set, these two PFLUSH variants can be used to flush only user address translation cache entries during task swaps.

### **Condition Codes:**

Not affected.

Flush ATC Entries (MC68040, MC68LC040)

**PFLUSH** 

### **Instruction Format:**

Postincrement Source and Destination

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3   | 2   | 1      | 0   |
|----|----|----|----|----|----|---|---|---|---|---|---|-----|-----|--------|-----|
| 1  | 1  | 1  | 1  | 0  | 1  | 0 | 1 | 0 | 0 | 0 |   | ODE | ı K | EGISTE | K I |

### **Instruction Fields:**

Opmode field—Specifies the flush operation.

| Opcode | Operation                       | Assembler Syntax |
|--------|---------------------------------|------------------|
| 00     | Flush page entry if not global  | PFLUSHN (An)     |
| 01     | Flush page entry                | PFLUSH (An)      |
| 10     | Flush all except global entries | PFLUSHAN         |
| 11     | Flush all entries               | PFLUSHA          |

Register field—Specifies the address register containing the effective address to be flushed when flushing a page entry.

Flush ATC Entries (MC68EC040)

**PFLUSH** 

**Operation:** If Supervisor State

Then No Operation

Else TRAP

**Assembler** PFLUSH (An) **Syntax:** PFLUSHN (An)

Attributes: Unsized

**Description:** This instruction should not be executed when using an MC68EC040. The PFLUSH encoding suspends operation of the MC68EC040 for an indefinite period of time and subsequently continues with no adverse effects.

### **Condition Codes:**

Not affected.

### **Instruction Format:**

Postincrement Source and Destination

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4     | 3   | 2 | 1       | 0   |
|----|----|----|----|----|----|---|---|---|---|---|-------|-----|---|---------|-----|
| 1  | 1  | 1  | 1  | 0  | 1  | 0 | 1 | 0 | 0 | 0 | I OPM | ODE | R | EGISTEI | к і |

### **Instruction Fields:**

Opmode field—Specifies the flush operation.

| Opcode | Operation                       | Assembler Syntax |
|--------|---------------------------------|------------------|
| 00     | Flush page entry if not global  | PFLUSHN (An)     |
| 01     | Flush page entry                | PFLUSH (An)      |
| 10     | Flush all except global entries | PFLUSHAN         |
| 11     | Flush all entries               | PFLUSHA          |

Register field—Specifies the address register containing the effective address to be flushed when flushing a page entry.

PFLUSHA PFLUSHS

## Invalidate Entries in the ATC (MC68851)

PFLUSHA PFLUSHS

**Operation:** If Supervisor State

Then Address Translation Cache Entries For Destination Address

Are Invalidated

Else TRAP

Assembler PFLUSHA

**Syntax:** PFLUSH FC,MASK

PFLUSHS FC,MASK

PFLUSH FC,MASK, < ea > PFLUSHS FC,MASK, < ea >

Attributes: Unsigned

**Description:** PFLUSHA invalidates all entries in the address translation cache.

PFLUSH invalidates a set of address translation cache entries whose function code bits satisfy the relation: (address translation cache function code bits and mask) = (FC and MASK) for all entries whose task alias matches the task alias currently active when the instruction is executed. With an additional effective address argument, PFLUSH invalidates a set of address translation cache entries whose function code satisfies the relation above and whose effective address field matches the corresponding bits of the evaluated effective address argument. In both of these cases, address translation cache entries whose SG bit is set will not be invalidated unless the PFLUSHS is specified.

The function code for this operation may be specified as follows:

- 1. Immediate—The function code is four bits in the command word.
- 2. Data Register—The function code is in the lower four bits of the MC68020 data register specified in the instruction.
- 3. Source Function Code (SFC) Register—The function code is in the CPU SFC register. Since the SFC of the MC68020 has only three implemented bits, only function codes \$0D\$7 can be specified in this manner.
- 4. Destination Function Code (DFC) Register—The function code is in the CPU DFC register. Since the DFC of the MC68020 has only three implemented bits, only function codes \$0D\$7 can be specified in this manner.



### Invalidate Entries in the ATC (MC68851)



PMMU Status Register: Not affected.

### **Instruction Format:**

| 15 | 14 | 13 | 12 | 11   | 10 | 9 | 8 | 7  | 6  | 5                 | 4    | 3 | 2  | 1      | 0 |  |  |  |
|----|----|----|----|------|----|---|---|----|----|-------------------|------|---|----|--------|---|--|--|--|
| 1  | 1  | 1  | 1  | 0    | 0  | 0 | 0 | 0  | 0  | EFFECTIVE ADDRESS |      |   |    |        |   |  |  |  |
| ı  | '  | '  | '  | "    | "  |   |   | "  | 0  |                   | MODE |   | R  | EGISTE | R |  |  |  |
| 0  | 0  | 1  |    | MODE |    | 0 |   | MA | SK | •                 |      |   | FC |        |   |  |  |  |

### **Instruction Fields:**

Effective Address field—Specifies an address whose page descriptor is to be flushed from (invalidated) the address translation cache. Only control alterable addressing modes can be used as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn                      | _    | _              |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | _    | _              |
| —(An)                   | _    | _              |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn] ,od)        | 110  | reg. number:An |
| ([bd,An],Xn ,od)        | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | _    | _        |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | _    | _        |
| (d <sub>8</sub> ,PC,Xn) | _    | _        |
| (bd,PC,Xn)              | _    | _        |
| ([bd,PC,Xn],od)         | _    | _        |
| ([bd,PC],Xn ,od)        | _    | _        |

PFLUSHA PFLUSHS

## Invalidate Entries in the ATC (MC68851)

PFLUSHA PFLUSHS

#### **NOTE**

The effective address field must provide the MC68851 with the effective address of the entry to be flushed from the address translation cache, not the effective address describing where the PFLUSH operand is located. For example, in order to flush the address translation cache entry corresponding to a logical address that is temporarily stored on the top of the system stack, the instruction PFLUSH [(SP)] must be used since PFLUSH (SP) would invalidate the address translation cache entry mapping the system stack (i.e., the effective address passed to the MC68851 is the effective address of the system stack, not the effective address formed by the operand located on the top of the stack).

Mode field—Specifies how the address translation cache is to be flushed.

001—Flush all entries.

100—Flush by function code only.

101—Flush by function code including shared entries.

110—Flush by function code and effective address.

111—Flush by function code and effective address including shared entries.

Mask field—Indicates which bits are significant in the function code compare. A zero indicates that the bit position is not significant; a one indicates that the bit position is significant. If mode = 001 (flush all entries), mask must be 0000.

FC field—Function code of address to be flushed. If the mode field is 001 (flush all entries), function code must be 00000; otherwise:

1DDDD — Function code is specified as four bits DDDD.

01RRR — Function code is contained in CPU data register RRR.

00000 — Function code is contained in CPU SFC register.

00001 — Function code is contained in CPU DFC register.

## PFLUSHR Invalidate ATC and RPT Entries PFLUSHR (MC68851)

**Operation:** If Supervisor State

Then RPT Entry (If Any) Matching Root Pointer Specified by < ea > Corresponding Address Translation Cache Entries Are Invalidated

Else TRAP

Assembler

Syntax: PFLUSHR < ea >

Attributes: Unsized

**Description:** The quad word pointed to by < ea > is regarded as a previously used value of the CPU root pointer register. The root pointer table entry matching this CPU root pointer register (if any) is flushed, and all address translation cache entries loaded with this value of CPU root pointer register (except for those that are globally shared) are invalidated. If no entry in the root pointer table matches the operand of this instruction, no action is taken.

If the supervisor root pointer is not in use, the operating system should not issue the PFLUSHR command to destroy a task identified by the current CPU root pointer register. It should wait until the CPU root pointer register has been loaded with the root pointer identifying the next task until using the PFLUSHR instruction. At any time, execution of the PFLUSHR instruction for the current CPU root pointer register causes the current task alias to be corrupted.

### **Instruction Format:**

| 15 | 14 | 13    | 12    | 11    | 10 | 9 | 8 | 7 | 6 | 5                 | 4 | 3 | 2    | 1 | 0 |        |   |
|----|----|-------|-------|-------|----|---|---|---|---|-------------------|---|---|------|---|---|--------|---|
| 1  | 1  | 1     | 1     | 0     | 0  | 0 | _ | 0 | 0 | EFFECTIVE ADDRESS |   |   |      |   |   |        |   |
| '  | '  | '   ' | '   ' | '   ' | 0  | 0 |   | U | " |                   | U |   | MODE |   | R | EGISTE | R |
| 1  | 0  | 1     | 0     | 0     | 0  | 0 | 0 | 0 | 0 | 0                 | 0 | 0 | 0    | 0 | 0 |        |   |

### PFLUSHR Invalidate ATC and RPT Entries PFLUSHR (MC68851)

### **Instruction Field:**

Effective Address field—Specifies the address of a previous value of the CPU root pointer register register. Only memory addressing modes can be used as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn                      | _    | _              |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| —(An)                   | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn] ,od)        | 110  | reg. number:An |
| ([bd,An],Xn ,od)        | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | 111  | 100      |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |
| ([bd,PC,Xn] ,od)        | 111  | 011      |
| ([bd,PC],Xn ,od)        | 111  | 011      |

### NOTE

The effective address usage of this instruction is different than that of other PFLUSH variants.

## Load an Entry into the ATC (MC68030 only, MC68851)

**PLOAD** 

**Operation:** If Supervisor State

Then Search Translation Table and Make Address Translation

Cache Entry for Effective Address

Else TRAP

**Assembler** PLOADR FC, < ea > **Syntax:** PLOADW FC, < ea >

Attributes: Unsized

**Description:** For the MC68851, PLOAD searches the translation table for a translation of the specified effective address. If one is found, it is flushed from the address translation cache, and an entry is made as if a bus master had run a bus cycle. Used and modified bits in the table are updated as part of the table search. The MC68851 ignores the logical bus arbitration signals during the flush and load phases at the end of this instruction. This prevents the possibility of an entry temporarily disappearing from the address translation cache and causing a false table search.

This instruction will cause a paged memory management unit illegal operation exception (vector \$39) if the E-bit of the translation control register is clear.

The function code for this operation may be specified to be:

- 1. Immediate—The function code is specified as four bits in the command word.
- 2. Data Register—The function code is contained in the lower four bits in the MC68020 data register specified in the instruction.
- 3. Source Function Code (SFC) Register—The function code is in the CPU SFC register. Since the SFC of the MC68020 has only three implemented bits, only function codes \$0D\$7 can be specified in this manner.
- 4. Destination Function Code (DFC) Register—The function code is in the CPU DFC register. Since the DFC of the MC68020 has only three implemented bits, only function codes \$0D\$7 can be specified in this manner.

### Load an Entry into the ATC (MC68030 only, MC68851)

**PLOAD** 

For the MC68030, PLOAD searches the address translation cache for the specified effective address. It also searches the translation table for the descriptor corresponding to the specified effective address. It creates a new entry as if the MC68030 had attempted to access that address. Sets the used and modified bits appropriately as part of the search. The instruction executes despite the value of the E-bit in the translation control register or the state of the MMUDIS signal.

The < function code > operand is specified in one of the following ways:

- 1. Immediate—Three bits in the command word.
- 2. Data Register—The three least significant bits of the data register specified in the instruction.
- 3. Source Function Code (SFC) Register
- 4. Destination Function Code (DFC) Register

The effective address field specifies the logical address whose translation is to be loaded.

PLOADR causes U bits in the translation tables to be updated as if a read access had occurred. PLOADW causes U and M bits in the translation tables to be updated as if a write access had occurred.

**PMMU Status Register:** Not affected.

#### **Instruction Format:**

| 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8 | 7 | 6 | 5 | 4    | 3      | 2            | 1      | 0  |
|----|----|----|----|----|----|-----|---|---|---|---|------|--------|--------------|--------|----|
| 1  | 1  | 1  | 1  | 0  | 0  | 0   | 0 | 0 | 0 |   | EFF  | ECTIVE | TIVE ADDRESS |        |    |
| '  | '  | '  | '  | "  | "  | "   |   |   | 0 |   | MODE |        | R            | EGISTE | :R |
| 0  | 0  | 1  | 0  | 0  | 0  | R/W | 0 | 0 | 0 | 0 |      |        | FC           |        |    |

## Load an Entry into the ATC (MC68030 only, MC68851)

### **PLOAD**

#### Instruction Fields:

Effective Address field—Specifies the logical address whose translation is to be loaded into the address translation cache. Only control alterable addressing modes are allowed as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn                      | _    | _              |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | _    | _              |
| —(An)                   | _    | _              |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn] ,od)        | 110  | reg. number:An |
| ([bd,An],Xn ,od)        | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | _    |          |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | _    |          |
| (d <sub>8</sub> ,PC,Xn) | _    |          |
| (bd,PC,Xn)              | _    |          |
| ([bd,PC,Xn],od)         | _    | _        |
| ([bd,PC],Xn ,od)        | _    | _        |

#### **NOTE**

The effective address field must provide the MC68851 with the effective address of the entry to be loaded into the address translation cache, not the effective address describing where the PLOAD operand is located. For example, to load an address translation cache entry to map a logical address that is temporarily stored on the system stack, the instruction PLOAD [(SP)] must be used since PLOAD (SP) would load an address translation cache entry mapping the system stack (i.e., the effective address passed to the MC68851 is the effective address of the system stack, not the effective address formed by the operand located on the top of the stack).

R/W field—Specifies whether the tables should be updated for a read or a write.

1—Read

0—Write

## Load an Entry into the ATC (MC68030 only, MC68851)

**PLOAD** 

FC field (MC68851)—Function code of address to load.

1DDDD — Function code is specified as four bits DDDD.

01RRR — Function code is contained in CPU data register RRR.

00000 — Function code is contained in CPU SFC register.

00001 — Function code is contained in CPU DFC register.

FC field (MC68030)—Function code of address corresponding to entry to be loaded.

10XXX — Function code is specified as bits XXX.

01DDD — Function code is specified as bits 2–0 of data register DDD.

00000 — Function code is specified as SFC register.

00001 — Function code is specified as DFC register.

## Move to/from MMU Registers (MC68030 only)

**PMOVE** 

**Operation:** If Supervisor State

Then (Source)  $\rightarrow$  MRn or MRn  $\rightarrow$  (Destination)

Assembler PMOVE MRn, < ea > PMOVE < ea > ,MRn

PMOVEFD < ea > ,MRn

**Attributes:** Size = (Word, Long, Quad)

**Description:** Moves the contents of the source effective address to the specified memory management unit register or moves the contents of the memory management unit register to the destination effective address.

The instruction is a quad-word (8 byte) operation for the CPU root pointer and the supervisor root pointer. It is a long-word operation for the translation control register and the transparent translation registers (TT0 and TT1). It is a word operation for the MMU status register.

The PMOVEFD form of this instruction sets the FD-bit to disable flushing the address translation cache when a new value loads into the supervisor root pointer, CPU root pointer, TT0, TT1 or translation control register (but not the MMU status register).

Writing to the following registers has the indicated side effects:

CPU Root Pointer—When the FD-bit is zero, it flushes the address translation cache. If the operand value is invalid for a root pointer descriptor, the instruction takes an memory management unit configuration error exception after moving the operand to the CPU root pointer.

Supervisor Root Pointer—When the FD-bit is zero, it flushes the address translation cache. If the operand value is invalid as a root pointer descriptor, the instruction takes an memory management unit configuration error exception after moving the operand to the supervisor root pointer.

Translation Control Register—When the FD-bit is zero, it flushes the address translation cache. If the E-bit = 1, consistency checks are performed on the PS and Tlx fields. If the checks fail, the instruction takes an memory management unit configuration exception after moving the operand to the translation control register. If the checks pass, the translation control register is loaded with the operand and the E-bit is cleared.

TT0, TT1—When the FD-bit is zero, it flushes the address translation cache. It enables or disables the transparent translation register according to the E-bit written. If the E-bit = 1, the transparent translation register is enabled. If the E- bit = 0, the register is disabled.

## Move to/from MMU Registers (MC68030 only)

**PMOVE** 

### **Condition Codes:**

Not affected.

### **MMU Status Register:**

Not affected (unless the MMU status register is specified as the destination operand).

### **Instruction Format:**

SRP, CRP, and TC Registers

| 15 | 14 | 13 | 12 | 11     | 10 | 9   | 8  | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|----|----|----|--------|----|-----|----|---|---|---|------|---------|-------|--------|---|
| 1  | 1  | 1  | 1  | _      | 0  | _   | 0  | 0 | _ |   | EF   | FECTIVE | ADDRE | SS     |   |
| 1  | '  | '  | '  | "      | "  | "   | U  | " | " |   | MODE |         | R     | EGISTE | R |
| 0  | 1  | 0  | P- | REGIST | ER | R/W | FD | 0 | 0 | 0 | 0    | 0       | 0     | 0      | 0 |

### Instruction Fields:

Effective Address field—Specifies the memory location for the transfer. Only control alterable addressing modes can be used as in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn                      | _    | _              |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | _    | _              |
| —(An)                   | _    | _              |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn] ,od)        | 110  | reg. number:An |
| ([bd,An],Xn ,od)        | 110  | reg. number:An |

| 111 | 000                          |
|-----|------------------------------|
| 111 |                              |
|     | 001                          |
| _   | _                            |
|     |                              |
|     |                              |
| _   | _                            |
| _   | _                            |
| _   | _                            |
| _   | _                            |
| _   | _                            |
|     | 111<br>-<br>-<br>-<br>-<br>- |

## Move to/from MMU Registers (MC68030 only)

**PMOVE** 

P-Register field—Specifies the memory management unit register.

000—Translation Control Register

010—Supervisor Root Pointer

011—CPU Root Pointer

R/W field—Specifies the direction of transfer.

- 0—Memory to memeory management unit register.
- 1—Memeory management unit register to memory.

FD field—Disables flushing of the address translation cache on writes to memeory management unit registers.

- 0—Address translation cache is flushed.
- 1—Address translation cache is not flushed.

### **Instruction Format:**

#### MMU Status Register

| 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8 | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|----|----|----|----|----|-----|---|---|---|---|------|---------|-------|--------|---|
| 1  | 1  | 1  | 1  | 0  | 0  | 0   | 0 | 0 | 0 |   | EFI  | FECTIVE | ADDRE | SS     |   |
|    | '  | '  | '  | 0  | "  | "   | " | " | " |   | MODE |         | R     | EGISTE | R |
| 0  | 1  | 1  | 0  | 0  | 0  | R/W | 0 | 0 | 0 | 0 | 0    | 0       | 0     | 0      | 0 |

### **Instruction Fields:**

Effective Address field—Specifies the memory location for the transfer. Control alterable addressing modes shown for supervisor root pointer register apply.

R/W field—Specifies the direction of transfer.

- 0-Memory to MMU status register.
- 1—MMU status register to memory.

### **NOTE**

The syntax of assemblers for the MC68851 use the symbol PMMU status register for the MMU status register.

## Move to/from MMU Registers (MC68030 only)

### **PMOVE**

#### **Instruction Format:**

### TT Registers

| 1 | 5 | 14 | 13 | 12 | 11     | 10 | 9   | 8  | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|---|---|----|----|----|--------|----|-----|----|---|---|---|------|---------|-------|--------|---|
|   | , | 1  | 1  | 1  | 0      |    | _   | 0  | 0 | _ |   | EF   | FECTIVE | ADDRE | SS     |   |
|   | 1 | '  | '  | '  |        | "  | "   |    | ١ | 0 |   | MODE |         | R     | EGISTE | R |
|   | 0 | 0  | 0  | P- | REGIST | ER | R/W | FD | 0 | 0 | 0 | 0    | 0       | 0     | 0      | 0 |

### **Instruction Fields:**

Effective Address field—Specifies the memory location for the transfer. Control alterable addressing modes shown for supervisor root pointer register apply.

P-Register field—Specifies the transparent translation register.

010—Transparent Translation Register 0

011—Transparent Translation Register 1

R/W field—Specifies the direction of transfer.

0—Memory to MMU status register.

1—MMU status register to memory.

FD field—Disables flushing of the address translation cache.

0—Address translation cache is flushed.

1—Address translation cache does not flush.

## Move to/from MMU Registers (MC68EC030)

**PMOVE** 

**Operation:** If Supervisor State

Then (Source)  $\rightarrow$  MRn or MRn  $\rightarrow$  (Destination)

Assembler PMOVE MRn, < ea > Syntax: PMOVE < ea > ,MRn

**Attributes:** Size = (Word, Long, Quad)

**Description:** Moves the contents of the source effective address to an access control register or moves the contents of an access control register to the destination effective address.

The instruction is a long-word operation for the access control registers (AC0 and AC1). It is a word operation for the access control unit status register (ACUSR).

Writing to the ACx registers enables or disables the access control register according to the E-bit written. If the E-bit = 1, the access control register is enabled. If the E-bit = 0, the register is disabled

### **Condition Codes:**

Not affected.

#### ACUSR:

Not affected unless the ACUSR is specified as the destination operand.

### **Instruction Format:**

#### **ACUSR**

| 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8 | 7 | 6 | 5    | 4  | 3       | 2         | 1 | 0 |  |
|----|----|----|----|----|----|-----|---|---|---|------|----|---------|-----------|---|---|--|
| 1  | 1  | 1  | 1  | 0  | 0  | 0   | 0 | 0 | 0 |      | EF | FECTIVE | E ADDRESS |   |   |  |
| '  | '  | '  | '  |    |    | 0   |   | 0 | 0 | MODE |    |         | REGISTER  |   |   |  |
| 0  | 1  | 1  | 0  | 0  | 0  | R/W | 0 | 0 | 0 | 0    | 0  | 0       | 0         | 0 | 0 |  |

### Instruction Fields:

Effective Address field—Specifies the memory location for the transfer.

R/W field—Specifies the direction of transfer.

0—Memory to ACUSR

1—ACUSR to memory

## Move to/from MMU Registers (MC68EC030)

**PMOVE** 

### NOTE

Assembler syntax for the MC68851 uses the symbol PMMU status register for the ACUSR; and for the MC68030, the symbols TT0 and TT1 for AC0 and AC1.

### **Instruction Format:**

### **ACx Registers**

|   | 15 | 14 | 13 | 12 | 11     | 10 | 9   | 8 | 7 | 6 | 5  | 4             | 3       | 2     | 1  | 0 |   |
|---|----|----|----|----|--------|----|-----|---|---|---|----|---------------|---------|-------|----|---|---|
| ſ | 1  | 1  | 1  | 1  | 0      | 0  | 0   | 0 | 0 | 0 |    | EF            | FECTIVE | ADDRE | SS |   |   |
|   | '  | '  | '  | '  | "      | "  | "   | " | " | " | MC | MODE REGISTER |         |       |    |   | R |
| ſ | 0  | 0  | 0  | P- | REGIST | ER | R/W | 0 | 0 | 0 | 0  | 0             | 0       | 0     | 0  | 0 |   |

#### Instruction Fields:

Effective Address field—Specifies the memory location for the transfer.

P-Register field—Specifies the ACx register.

001—Access Control Register 0

011—Access Control Register 1

R/W field—Specifies the direction of transfer.

0—Memory to ACUSR

1—ACUSR to memory

## Move PMMU Register (MC68851)

**PMOVE** 

**Operation:** If Supervisor State

Then MC68851 Register →Destination

Or Source → MC68851 Register

Else TRAP

Assembler PMOVE < PMMU Register > , < ea > Syntax: PMOVE < ea > , < PMMU Register >

**Attributes:** Size = (Byte, Word, Long, Double Long)

**Description:** The contents of the MC68851 register copies to the address specified by < ea > , or the data at < ea > copies into the MC68851 register.

The instruction is a quad-word operation for CPU root pointer, supervisor root pointer, and DMA root pointer registers. It is a long-word operation for the translation control register and a word operation for the breakpoint acknowledge control, breakpoint acknowledge data, access control, PMMU status, and PMMU cache status registers. PMOVE is a byte operation for the current access level, valid access level, and stack change control registers.

The following side effects occur when data is read into certain registers:

CPU Root Pointer—Causes the internal root pointer table to be searched for the new value. If there is no matching value, an entry in the root pointer table is selected for replacement, and all address translation cache entries associated with the replaced entry are invalidated.

Supervisor Root Pointer—Causes all entries in the address translation cache that were formed with the supervisor root pointer (even globally shared entries) to be invalidated.

DMA Root Pointer—Causes all entries in the address translation cache that were formed with the DMA root pointer (even globally shared entries) to be invalidated.

Translation Control Register—If data written to the translation control register attempts to set the E-bit and the E-bit is currently clear, a consistency check is performed on the IS, TIA, TIB, TIC, TID, and PS fields.

### **PMOVE**

## Move PMMU Register (MC68851)

**PMOVE** 

**PMMU Status Register:** Not affected unless the PMMU status register is written to by the instruction.

#### **Instruction Format 1:**

PMOVE to/from TC, CRP, DRP, SRP, CAL, VAL, SCC, AC

| 15 | 14 | 13 | 12 | 11     | 10 | 9   | 8 | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|----|----|----|--------|----|-----|---|---|---|---|------|---------|-------|--------|---|
| 1  | 1  | 1  | 1  | 0      | 0  | 0   | 0 | 0 | 0 |   | EF   | FECTIVE | ADDRE | SS     |   |
| '  | '  | '  | '  | "      | "  | "   |   | " | " |   | MODE |         | R     | EGISTE | R |
| 0  | 1  | 0  | P- | REGIST | ER | R/W | 0 | 0 | 0 | 0 | 0    | 0       | 0     | 0      | 0 |

#### **Instruction Fields:**

Effective Address field—for memory-to-register transfers, any addressing mode is allowed as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn*                     | 000  | reg. number:Dn |
| An*                     | 001  | reg. number:An |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| —(An)                   | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn] ,od)        | 110  | reg. number:An |
| ([bd,An],Xn ,od)        | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | 111  | 100      |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |
| ([bd,PC,Xn] ,od)        | 111  | 011      |
| ([bd,PC],Xn ,od)        | 111  | 011      |

<sup>\*</sup>PMOVE to CRP, SRP, and DMA root pointer not allowed with these modes

### **PMOVE**

## Move PMMU Register (MC68851)

**PMOVE** 

For register-to-memory transfers, only alterable addressing modes can be used as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn*                     | 000  | reg. number:Dn |
| An*                     | 001  | reg. number:An |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| —(An)                   | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn] ,od)        | 110  | reg. number:An |
| ([bd,An],Xn ,od)        | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | _    | _        |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | _    |          |
| (d <sub>8</sub> ,PC,Xn) | _    | _        |
| (bd,PC,Xn)              | _    | _        |
| ([bd,PC,Xn],od)         | _    | _        |
| ([bd,PC],Xn ,od)        | _    | _        |

<sup>\*</sup>PMOVE to CRP, SRP, and DMA root pointer not allowed with these modes

Register field—Specifies the MC68851 register.

000—Translation Control Register

001—DMA Root Pointer

010—Supervisor Root Pointer

011—CPU Root Pointer

100—Current Access Level

101—Valid Access Level

110—Stack Change Control Register

111—Access Control Register

R/W field—Specifies the direction of transfer.

0—Transfer < ea > to MC68851 register.

1—Transfer MC68851 register to < ea > .

#### **Instruction Format 2:**

#### PMOVE to/from BADx, BACx

| 15 | 14 | 13 | 12 | 11      | 10 | 9   | 8 | 7 | 6 | 5 | 4    | 3      | 2     | 1      | 0 |
|----|----|----|----|---------|----|-----|---|---|---|---|------|--------|-------|--------|---|
| 1  | 1  | 1  | 1  | 0       | 0  | 0   | 0 | _ | _ |   | EFF  | ECTIVE | ADDRE | SS     |   |
| '  | '  | '  | '  | 0       | U  | 0   | U | " | 0 |   | MODE |        | R     | EGISTE | R |
| 0  | 1  | 1  | P- | REGISTI | ER | R/W | 0 | 0 | 0 | 0 |      | NUM    |       | 0      | 0 |

### **PMOVE**

## Move PMMU Register (MC68851)

### **PMOVE**

#### **Instruction Fields:**

Effective Address field—Same as format 1.

P-Register field—Specifies the type of MC68851 register.

100—Breakpoint Acknowledge Data

101—Breakpoint Acknowledge Control

R/W field—Specifies the direction of transfer.

0—Transfer < ea > to MC68851 register

1—Transfer MC68851 register to < ea >

Num field—Specifies the number of the BACx or BADx register to be used.

#### **Instruction Format 3:**

#### PMOVE to/from PSR, from PCSR

| 15 | 14 | 13 | 12 | 11     | 10 | 9   | 8 | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|----|----|----|--------|----|-----|---|---|---|---|------|---------|-------|--------|---|
| 1  | 1  | 1  | 1  | _      | _  |     | _ | 0 | _ |   | EF   | FECTIVE | ADDRE | SS     |   |
| '  | '  | '  | '  | "      | "  | "   | " | 0 | " |   | MODE |         | R     | EGISTE | R |
| 0  | 1  | 1  | P- | REGIST | ER | R/W | 0 | 0 | 0 | 0 | 0    | 0       | 0     | 0      | 0 |

#### **Instruction Fields:**

Effective Address field—Same as format 1.

P Register field—Specifies the MC68851 register.

000 — PMMU Status Register

001 — PMMU Cache Status Register

R/W field—Specifies direction of transfer.

- 0—Transfer < ea > to MC68851 register.
- 1—Transfer MC68851 register to < ea > (must be one to access PMMU cache status register using this format).

### PRESTORE PMMU Restore Function

## (MC68851)

## **PRESTORE**

Operation: If Supervisor State

Then MC68851 State Frame → Internal State, Programmer

Registers Else TRAP

**Assembler** 

PRESTORE < ea > Syntax:

Attributes: Unsized, Privileged

**Description:** The MC68851 aborts execution of any operation in progress. New programmer registers and internal states are loaded from the state frame located at the effective address. The first word at the specified address is the format word of the state frame, specifying the size of the frame and the revision number of the MC68851 that created it. The MC68020 writes the first word to the MC68851 restore coprocessor interface register, initiating the restore operation. Then it reads the response coprocessor interface register to verify that the MC68851 recognizes the format as valid. The format is invalid if the MC68851 does not recognize the frame size or the revision number does not match. If the format is invalid, the MC68020 takes a format exception, and the MC68851 returns to the idle state with its user visible registers unchanged. However, if the format is valid, then the appropriate state frame loads, starting at the specified location and proceeding up through the higher addresses.

The PRESTORE instruction restores the nonuser visible state of the MC68851 as well as the PMMU status register, CPU root pointer, supervisor root pointer, current access level, valid access level, and stack change control registers of the user programming model. In addition, if any breakpoints are enabled, all breakpoint acknowledge control and breakpoint acknowledge data registers are restored. This instruction is the inverse of the PSAVE instruction.

The current implementation of the MC68851 supports four state frame sizes:

NULL: This state frame is 4 bytes long, with a format word of \$0. A PRESTORE with

this size state frame places the MC68851 in the idle state with no coproces-

sor or module operations in progress.

IDLE: This state frame is 36 (\$24) bytes long. A PRESTORE with this size state

> frame causes the MC68851 to place itself in an idle state with no coprocessor operations in progress and no breakpoints enabled. A module operation may or may not be in progress. This state frame restores the minimal set of

MC68851 registers.

### PRESTORE PMMU Restore Function (MC68851)

## **PRESTORE**

MID-COPROCESSOR: This state frame is 44 (\$2C) bytes long. A PRESTORE with this size frame restores the MC68851 to a state with a coprocessor operation in progress and no breakpoints enabled.

BREAKPOINTS ENABLED: This state frame is 76 (\$4C) bytes long. A PRESTORE with this size state frame restores all breakpoint registers, along with other states. A coprocessor operation may or may not be in progress.

**PMMU Status Register:** Set according to restored data.

#### **Instruction Format:**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4    | 3      | 2     | 1      | 0 |
|----|----|----|----|----|----|---|---|---|---|---|------|--------|-------|--------|---|
| 1  | 1  | 1  | 1  | 0  | 0  | 0 | 1 | _ | 1 |   | EFI  | ECTIVE | ADDRE | SS     |   |
| '  | '  | 1  | 1  | U  | 0  | " | 1 | " | 1 |   | MODE |        | R     | EGISTE | R |

#### **Instruction Fields:**

Effective Address field—Specifies the source location. Only control or post-increment addressing modes can be used as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn                      | _    | _              |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| —(An)                   | _    | _              |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn] ,od)        | 110  | reg. number:An |
| ([bd,An],Xn ,od)        | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | _    | _        |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |
| ([bd,PC,Xn],od)         | 111  | 011      |
| ([bd,PC],Xn ,od)        | 111  | 011      |

**PSAVE** 

## PMMU Save Function (MC68851)

**PSAVE** 

**Operation:** If Supervisor State

Then MC68851 Internal State, Programmer

Registers → State Frame

Else TRAP

**Assembler** 

Syntax: PSAVE < ea >

Attributes: Unsized, Privileged

**Description:** The MC68851 suspends execution of any operation that it is performing and saves its internal state and some programmer registers in a state frame located at the effective address. The following registers are copied: PMMU status, control root pointer, supervisor root pointer, current access level, valid access level, and stack change control. If any breakpoint is enabled, all breakpoint acknowledge control and breakpoint acknowledge data registers are copied. After the save operation, the MC68851 is in an idle state waiting for another operation to be requested. Programmer registers are not changed.

The state frame format saved by the MC68851 depends on its state at the time of the PSAVE operation. In the current implementation, three state frames are possible:

IDLE: This state frame is 36 (\$24) bytes long. A PSAVE of this size state frame indicates that the MC68851 was in an idle state with no coprocessor operations in progress and no breakpoints enabled. A module call operation may or may not have been in progress when this state frame was saved.

MID-COPROCESSOR: This state frame is 44 (\$2C) bytes long. A PSAVE of this size frame indicates that the MC68851 was in a state with a coprocessor or module call operation in progress and no breakpoints enabled.

BREAKPOINTS ENABLED: This state frame is 76 (\$4C) bytes long. A PSAVE of this size state frame indicates that one or more breakpoints were enabled. A coprocessor or module call operation may or may not have been in progress.

PMMU Status Register: Not affected

**PSAVE** 

## PMMU Save Function (MC68851)

**PSAVE** 

#### **Instruction Format:**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4    | 3      | 2     | 1      | 0 |
|----|----|----|----|----|----|---|---|---|---|---|------|--------|-------|--------|---|
| 1  | 1  | 1  | 1  | _  | _  | _ | 1 | _ | _ |   | EFF  | ECTIVE | ADDRE | SS     |   |
| '  | '  | '  | '  | "  | "  | " | ' | " | " |   | MODE |        | R     | EGISTE | R |

#### **Instruction Fields:**

Effective Address field—Specifies the destination location. Only control or predecrement addressing modes can be used as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn                      | _    | _              |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | _    | _              |
| —(An)                   | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn] ,od)        | 110  | reg. number:An |
| ([bd,An],Xn ,od)        | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |  |  |  |
|-------------------------|------|----------|--|--|--|
| (xxx).W                 | 111  | 000      |  |  |  |
| (xxx).L                 | 111  | 001      |  |  |  |
| # < data >              | _    |          |  |  |  |
|                         |      |          |  |  |  |
|                         |      |          |  |  |  |
| (d <sub>16</sub> ,PC)   | _    |          |  |  |  |
| (d <sub>8</sub> ,PC,Xn) | _    | _        |  |  |  |
| (bd,PC,Xn)              | _    | _        |  |  |  |
| ([bd,PC,Xn],od)         | _    | _        |  |  |  |
| ([bd,PC],Xn ,od)        | _    | _        |  |  |  |

**PScc** 

## Set on PMMU unit Condition (MC68851)

**PScc** 

**Operation:** If Supervisor State

Then If cc True

Then 1s  $\rightarrow$  Destination Else 0s  $\rightarrow$  Destination

Else TRAP

**Assembler** 

Syntax: PScc < ea >

**Attributes:** Size = (Byte)

**Description:** The specified MC68851 condition code is tested. If the condition is true, the byte specified by the effective address is set to TRUE (all ones); otherwise, that byte is set to FALSE (all zeros).

The condition code specifier cc may specify the following conditions:

| Specifier | Description | Condition Field |
|-----------|-------------|-----------------|
| BS        | B set       | 000000          |
| LS        | L set       | 000010          |
| SS        | S set       | 000100          |
| AS        | A set       | 000110          |
| WS        | W set       | 001000          |
| IS        | I set       | 001010          |
| GS        | G set       | 001100          |
| CS        | C set       | 001110          |

| Specifier | Description | Condition Field |  |  |  |  |  |
|-----------|-------------|-----------------|--|--|--|--|--|
| ВС        | B clear     | 000001          |  |  |  |  |  |
| LC        | L clear     | 000011          |  |  |  |  |  |
| SC        | S clear     | 000101          |  |  |  |  |  |
| AC        | A clear     | 000111          |  |  |  |  |  |
| WC        | W clear     | 001001          |  |  |  |  |  |
| IC        | I clear     | 001011          |  |  |  |  |  |
| GC        | G clear     | 001101          |  |  |  |  |  |
| CC        | C clear     | 001111          |  |  |  |  |  |

PMMU Status Register: Not affected

**PScc** 

## Set on PMMU Condition (MC68851)

**PScc** 

#### **Instruction Format:**

|   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5                 | 4           | 3 | 2     | 1      | 0 |
|---|----|----|----|----|----|----|---|---|---|---|-------------------|-------------|---|-------|--------|---|
|   | 4  | 4  | 1  | 4  | _  | _  | _ | _ | _ | 4 |                   | EFFECTIVE A |   | ADDRE | SS     |   |
|   | 1  | '  | '  | '  | 0  | "  | " | " | " | ' |                   | MODE        |   | F     | EGISTE | R |
| Ī | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | MC68851 CONDITION |             |   |       |        |   |

#### **Instruction Fields:**

Effective Address field—Specifies the destination location. Only data alterable addressing modes can be used as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn                      | 000  | reg. number:Dn |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | 011  | reg. number:An |
| —(An)                   | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn] ,od)        | 110  | reg. number:An |
| ([bd,An],Xn,od)         | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | _    | _        |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | _    | 1        |
| (d <sub>8</sub> ,PC,Xn) | _    |          |
| (bd,PC,Xn)              | _    |          |
| ([bd,PC,Xn] ,od)        | _    | _        |
| ([bd,PC],Xn ,od)        | _    | _        |

MC68851 Condition field—Specifies the coprocessor condition to be tested. This field is passed to the MC68851, which provides directives to the main processor for processing this instruction.

## Test a Logical Address (MC68030 only)

**PTEST** 

**Operation:** If Supervisor State

Then Logical Address Status → MMUSR

Else TRAP

Assembler PTESTR FC, < ea > ,# < level > Syntax: PTESTR FC, < ea > ,# < level > ,An

PTESTW FC, < ea > ,# < level > PTESTW FC, < ea > ,# < level > ,An

Attributes: Unsized

**Description:** This instruction searches the address translation cache or the translation tables to a specified level. Searching for the translation descriptor corresponding to the < ea > field, it sets the bits of the MMU status register according to the status of the descriptor. Optionally, PTEST stores the physical address of the last table entry accessed during the search in the specified address register. The PTEST instruction searches the address translation cache or the translation tables to obtain status information, but alters neither the used or modified bits of the translation tables nor the address translation cache. When the level operand is zero, only the transparent translation of either read or write accesses causes the operations of the PTESTR and PTESTW to return different results.

The < function code > operand is specified as one of the following:

- 1. Immediate—Three bits in the command word.
- 2. Data Register—The three least significant bits of the data register specified in the instruction.
- 3. Source Function Code (SFC) Register
- 4. Destination Function Code (DFC) Register

The effective address is the address to test. The < level > operand specifies the level of the search. Level 0 specifies searching the addrass translation cache only. Levels 1–7 specify searching the translation tables only. The search ends at the specified level. A level 0 test does not return the same MMU status register values as a test at a nonzero level number.

Execution of the instruction continues to the requested level or until detecting one of the following conditions:

- Invalid Descriptor
- Limit Violation
- Bus Error Assertion (Physical Bus Error)

## Test a Logical Address (MC68030 only)

**PTEST** 

The instruction accumulates status as it accesses successive table entries. When the instruction specifies an address translation cache search with an address register operand, the MC68030 takes an F-line unimplemented instruction exception.

If there is a parameter specification for a translation table search, the physical address of the last descriptor successfully fetched loads into the address register. A successfully fetched descriptor occurs only if all portions of the descriptor can be read by the MC68030 without abnormal termination of the bus cycle. If the root pointer's DT field indicates page descriptor, the returned address is \$0. For a long descriptor, the address of the first long word is returned. The size of the descriptor (short or long) is not returned and must be determined from a knowledge of the translation table.

#### **Condition Codes:**

Not affected.

#### MMUSR:

| В | L | S |   | W | I | M |   |   | Т |   |   |   | N |  |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|--|
| * | * | * | 0 | * | * | * | 0 | 0 | 0 | 0 | 0 | 0 | * |  |

## Test a Logical Address (MC68030 only)

**PTEST** 

The MMU status register contains the results of the search. The values in the fields of the MMU status register for an address translation cache search are given in the following table:

| MMUSR Bit                     | PTEST, Level 0                                                                                                                                                                                      | PTEST, Levels 1–7                                                                                                                                                                                                                                                                  |
|-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bus Error (B)                 | This bit is set if the bus error bit is set in the ATC entry for the specified logical address.                                                                                                     | This bit is set if a bus error is encountered during the table search for the PTEST instruction.                                                                                                                                                                                   |
| Limit (L)                     | This bit is cleared.                                                                                                                                                                                | This bit is set if an index exceeds a limit during the table search.                                                                                                                                                                                                               |
| Supervis or<br>Violatio n (S) | This bit is cleared.                                                                                                                                                                                | This bit is set if the S-bit of a long (S) format table descriptor or long format page descriptor encountered during the search is set and if the FC2-bit of the function code specified by the PTEST instruction is not equal to one. The S-bit is undefined if the I-bit is set. |
| Write<br>Protecte d (W)       | The bit is set if the WP-bit of the ATC entry is set. It is undefined if the I-bit is set.                                                                                                          | This bit is set if a descriptor or page descriptor is encountered with the WP-bit set during the table search. The W-bit is undefined if the I-bit is set.                                                                                                                         |
| Invalid (I)                   | This bit indicates an invalid translation. The I- bit is set if the translation for the specified logical address is not resident in the ATC or if the B-bit of the corresponding ATC entry is set. | This bit indicates an invalid translation. The I-bit is set if the DT field of a table or a page descriptor encountered during the search is set to invalid or if either the B or L bits of the MMUSR are set during the table search.                                             |
| Modified (M)                  | This bit is set if the ATC entry corresponding to the specified address has the modified bit set. It is undefined if the I-bit is set.                                                              | This bit is set if the page descriptor for the specified address has the modified bit set. It is undefined if I-bit is set.                                                                                                                                                        |
| Transparent (T)               | This bit is set if a match occurred in either (or both) of the transparent translation registers (TT0 or TT1).                                                                                      | This bit is set to zero.                                                                                                                                                                                                                                                           |
| Number of<br>Levels (N)       | This 3-bit field is set to zero.                                                                                                                                                                    | This 3-bit field contains the actual number of tables accessed during the search.                                                                                                                                                                                                  |

## Test a Logical Address (MC68030 only)

### **PTEST**

#### **Instruction Format:**

| 15 | 14 | 13 | 12 | 11          | 10 | 9 | 8 | 7    | 6    | 5                | 4    | 3 | 2 | 1      | 0 |
|----|----|----|----|-------------|----|---|---|------|------|------------------|------|---|---|--------|---|
| 1  | 1  | 1  | 1  | _           | 0  | _ | 0 | _    | 0    | EFFECTIVE ADDRES |      |   |   | SS     |   |
| 1  |    |    | '  | "           | 0  |   |   | "    |      |                  | MODE |   | R | EGISTE | R |
| 1  | 0  | 0  |    | LEVEL R/W A |    |   |   | REGI | STER |                  | FC   |   |   |        |   |

#### **Instruction Fields:**

Effective Address field—Specifies the logical address to be tested. Only control alterable addressing modes can be used as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn                      | _    | _              |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | _    | _              |
| —(An)                   | _    | _              |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn] ,od)        | 110  | reg. number:An |
| ([bd,An],Xn ,od)        | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |  |  |  |
|-------------------------|------|----------|--|--|--|
| (xxx).W                 | 111  | 000      |  |  |  |
| (xxx).L                 | 111  | 001      |  |  |  |
| # < data >              | _    |          |  |  |  |
|                         |      |          |  |  |  |
|                         |      |          |  |  |  |
| (d <sub>16</sub> ,PC)   | _    |          |  |  |  |
| (d <sub>8</sub> ,PC,Xn) | _    | _        |  |  |  |
| (bd,PC,Xn)              | _    |          |  |  |  |
| ([bd,PC,Xn] ,od)        |      |          |  |  |  |
| ([bd,PC],Xn ,od)        | _    | _        |  |  |  |
| ·                       |      |          |  |  |  |

Level field—Specifies the highest numbered level to be searched in the table. When this field contains 0, the A field and the register field must also be 0. The instruction takes an F-line exception when the level field is 0 and the A field is not 0.

R/W field—Specifies simulating a read or write bus cycle (no difference for MC68030 MMU).

0—Write

1—Read

A field—Specifies the address register option.

- 0—No address register.
- 1—Return the address of the last descriptor searched in the address register specified in the register field.

## Test a Logical Address (MC68030 only)

**PTEST** 

Register field—Specifies an address register for the instruction. When the A field contains 0, this field must contain 0.

FC field—Function code of address to be tested.

10XXX — Function code is specified as bits XXX.

01DDD — Function code is specified as bits 2–0 of data register DDD.

00000 — Function code is specified as source function code register.

00001 — Function code is specified as destination function code register.

## Test a Logical Address (MC68EC030)

**PTEST** 

**Operation:** If Supervisor State

Then Logical Address Status → ACUSR

Else TRAP

**Assembler** PTESTR FC, < ea > **Syntax:** PTESTW FC, < ea >

Attributes: Unsized

**Description:** This instruction searches the access control registers for the address descriptor corresponding to the < ea > field and sets the bit of the access control unit status register (ACUSR) according to the status of the descriptor.

The < function code > operand is specified in one of the following ways:

- 1. Immediate—Three bits in the command word.
- 2. Data Register—The three least significant bits of the data register specified in the instruction.
- 3. Source Function Code (SFC) Register
- 4. Destination Function Code (DFC) Register

The effective address is the address to test.

#### **Condition Codes:**

Not affected.

#### ACUSR:

|   | _ |   |   |   |   |   |   |   |    |   |   |   |   |   |   |
|---|---|---|---|---|---|---|---|---|----|---|---|---|---|---|---|
| Х | х | х | 0 | х | х | х | 0 | 0 | AC | 0 | 0 | 0 | х | х | х |

x = May be 0 or 1.

The AC-bit is set if a match occurs in either (or both) of the access control registers.

#### **Instruction Format:**

| 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8 | 7        | 6 | 5                 | 4  | 3        | 2  | 1 | 0 |
|----|----|----|----|----|----|-----|---|----------|---|-------------------|----|----------|----|---|---|
| 1  | 4  | 4  | 4  | _  | 0  | _   | _ | _        | _ | EFFECTIVE ADDRESS |    |          |    |   |   |
| '  | '  | '  | '  | 0  | 0  | "   | 0 | "        | 0 | MODE              |    | REGISTER | :R |   |   |
| 1  | 0  | 0  | 0  | 0  | 0  | R/W | 0 | REGISTER |   |                   | FC |          |    |   |   |

## Test a Logical Address (MC68EC030)

### **PTEST**

#### **Instruction Fields:**

Effective Address field—Specifies the logical address to be tested. Only control alterable addressing modes can be used as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn                      | _    | _              |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | _    | _              |
| —(An)                   | _    | _              |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn] ,od)        | 110  | reg. number:An |
| ([bd,An],Xn ,od)        | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | _    | _        |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | _    | 1        |
| (d <sub>8</sub> ,PC,Xn) | _    | 1        |
| (bd,PC,Xn)              | _    | _        |
| ([bd,PC,Xn],od)         | _    |          |
| ([bd,PC],Xn ,od)        | _    | _        |

R/W field—Specifies simulating a read or write bus cycle.

0—Write

1—Read

Register field—Specifies an address register for the instruction. When the A field contains 0, this field must contain 0.

FC field—Function code of address to be tested.

10XXX — Function code is specified as bits XXX.

01DDD — Function code is specified as bits 2–0 of data register DDD.

00000 — Function code is specified as source function code register.

00001 — Function code is specified as destination function code register.

#### **NOTE**

Assembler syntax for the MC68030 is PTESTR FC, < ea > ,#0 and PTESTW FC, < ea > ,#0.

Test a Logical Address (MC68040, MC68LC040)

**PTEST** 

**Operation:** If Supervisor State

Then Logical Address Status  $\rightarrow$  MMUSR; Entry  $\rightarrow$  ATC

Else TRAP

Assembler PTESTR (An)
Syntax: PTESTW (An)

Attributes: Unsized

**Description:** This instruction searches the translation tables for the page descriptor corresponding to the test address in An and sets the bits of the MMU status register according to the status of the descriptors. The upper address bits of the translated physical address are also stored in the MMU status register. The PTESTR instruction simulates a read access and sets the U-bit in each descriptor during table searches; PTESTW simulates a write access and also sets the M-bit in the descriptors, the address translation cache entry, and the MMU status register.

A matching entry in the address translation cache (data or instruction) specified by the function code will be flushed by PTEST. Completion of PTEST results in the creation of a new address translation cache entry. The specification of the function code for the test address is in the destination function code (DFC) register. A PTEST instruction with a DFC value of 0, 3, 4, or 7 is undefined and will return an unknown value in the MMUSR.

Execution of the instruction continues until one of the following conditions occurs:

- Match with one of the two transparent translation registers.
- Transfer Error Assertion (physical transfer error)
- Invalid Descriptor
- Valid Page Descriptor

#### **Condition Codes:**

Not affected.

#### **MMU Status Register:**

| PHYSICAL ADDRESS | В | G | U1 | U0 | S | CM | M |   | W | Т | R |  |
|------------------|---|---|----|----|---|----|---|---|---|---|---|--|
| *                | * | * | *  | *  | * | *  | * | 0 | * | * | * |  |

## Test a Logical Address (MC68040, MC68LC040)

**PTEST** 

The MMUSR contains the results of the search. The values in the fields of the MMUSR for a search are:

Physical Address—This 20-bit field contains the upper bits of the translated physical address. Merging these bits with the lower bits of the logical address forms the actual physical address.

Bus Error (B)—Set if a transfer error is encountered during the table search for the PTEST instruction. If this bit is set, all other bits are zero.

Globally Shared (G)—Set if the G-bit is set in the page descriptor.

User Page Attributes (U1, U0)—Set if corresponding bits in the page descriptor are set.

Supervisor Protection (S)—Set if the S-bit in the page descriptor is set. This bit does not indicate that a violation has occurred.

Cache Mode (CM)—This 2-bit field is copied from the CM-bit in the page descriptor.

Modified (M)—Set if the M-bit is set in the page descriptor associated with the address.

Write Protect (W)—Set if the W-bit is set in any of the descriptors encountered during the table search. Setting of this bit does not indicate that a violation occurred.

Transparent Translation Register Hit (T)—Set if the PTEST address matches an instruction or data transparent translation register and the R-bit is set; all other bits are zero.

Resident (R)—Set if the PTEST address matches a transparent translation register or if the table search completes by obtaining a valid page descriptor.

#### **Instruction Format:**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5   | 4 | 3 | 2 | 1        | 0 |
|----|----|----|----|----|----|---|---|---|---|-----|---|---|---|----------|---|
| 1  | 1  | 1  | 1  | 0  | 1  | 0 | 1 | 0 | 1 | R/W | 0 | 1 |   | REGISTER |   |

#### **Instruction Fields:**

R/W field—Specifies simulating a read or write bus transfer.

0—Write

1—Read

Register field—Specifies the address register containing the effective address for the instruction.

## Test a Logical Address (MC68EC040)

**PTEST** 

**Operation:** If Supervisor State

Then No Operation, Possibly Run Extraneous Bus Cycles

Else TRAP

Assembler PTESTR (An)
Syntax: PTESTW (An)

Attributes: Unsized

**Description:** This instruction must not be executed on an MC68EC040. This instruction may cause extraneous bus cycles to occur and may result in unexpected exception types.

#### **Instruction Format:**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5   | 4 | 3 | 2 | 1        | 0 |
|----|----|----|----|----|----|---|---|---|---|-----|---|---|---|----------|---|
| 1  | 1  | 1  | 1  | 0  | 1  | 0 | 1 | 0 | 1 | R/W | 0 | 1 | R | REGISTER |   |

#### **Instruction Fields:**

R/W field—Specifies simulating a read or write bus transfer.

0—Write

1—Read

Register field—Specifies the address register containing the effective address for the instruction.

# PTEST Get Information About Logical Address PTEST (MC68851)

**Operation:** If Supervisor State

Then Information About Logical Address → PSTATUS

Else TRAP

Assembler PTESTR FC, < ea > ,# < level > ,(An)
Syntax: PTESTW FC, < ea > ,# < level > ,(An)

Attributes: Unsized

**Description:** If the E-bit of the translation control register is set, information about the logical address specified by FC and < ea > is placed in the PMMU status register. If the E-bit of the translation control register is clear, this instruction will cause a paged memory management unit illegal operation exception (vector \$39).

The function code for this operation may be specified as follows:

- 1. Immediate—The function code is four bits in the command word.
- 2. Data Register—The function code is in the lower four bits in the MC68020 data register specified in the instruction.
- Source Function Code (SFC) Register—The function code is in the SFC register
  in the CPU. Since the SFC of the MC68020 has only three implemented bits,
  only function codes \$0D\$7 can be specified in this manner.
- 4. Destination Function Code (DFC) Register—The function code is in the DFC register in the CPU. Since the DFC of the MC68020 has only three implemented bits, only function codes \$0D\$7 can be specified in this manner.

The effective address field specifies the logical address to be tested.

The # < level > parameter specifies the depth to which the translation table is to be searched. A value of zero specifies a search of the address translation cache only. Values 1–7 cause the address translation cache to be ignored and specify the maximum number of descriptors to fetch.

#### **NOTE**

Finding an address translation cache entry with < level > set to zero may result in a different value in the PMMU status register than forcing a table search. Only the I, W, G, M, and C bits of the PMMU status register are always the same in both cases.

## Get Information About Logical Address (MC68851)

**PTEST** 

Either PTESTR or PTESTW must be specified. These two instructions differ in the setting of the A-bit of the PMMU status register. For systems where access levels are not in use, either PTESTR or PTESTW may be used. U and M bits in the translation table are not modified by this instruction.

If there is a specified address register parameter, the physical address of the last successfully fetched descriptor is loaded into the address register. A descriptor is successfully fetched if all portions of the descriptor can be read by the MC68851 without abnormal termination of the bus cycle. If the DT field of the root pointer used indicates page descriptor, the returned address is \$0.

The PTEST instruction continues searching the translation tables until reaching the requested level or until a condition occurs that makes further searching impossible (i.e., a DT field set to invalid, a limit violation, or a bus error from memory). The information in the PMMU status register reflects the accumulated values.

#### **PMMU Status Register:**

- Bus Error (B)—Set if a bus error was received during a descriptor fetch, or if < level > = 0 and an entry was found in the address translation cache with its BERR bit set; cleared otherwise.
- Limit (L)—Set if the limit field of a long descriptor was exceeded; cleared otherwise.
- Supervisor Violation (S)—Set if a long descriptor indicated supervisor-only access and the < fc > parameter did not have bit 2 set; cleared otherwise.
- Access Level Violation (A)—If PTESTR was specified, set if the RAL field of a long descriptor would deny access. If PTESTW was specified, set if a WAL or RAL field of a long descriptor would deny access; cleared otherwise.
- Write Protection (W)—Set if the WP-bit of a descriptor was set or if a WAL field of a long descriptor would deny access; cleared otherwise.
- Invalid (I)—Set if a valid translation was not available; cleared otherwise.
- Modified (M)—If the tested address is found in the address translation cache, set to the value of the M-bit in the address translation cache. If the tested address is found in the translation table, set if the M-bit of the page descriptor is set; cleared otherwise.

## Get Information About Logical Address (MC68851)

**PTEST** 

Gate (G)—If the tested address is found in the address translation cache, set to the value of the G-bit in the address translation cache. If the tested address is found in the translation table, set if the G-bit of the page descriptor is set; cleared otherwise.

Globally Shared (C)—Set if the address is globally shared; cleared otherwise.

Level Number (N)—Set to the number of levels searched. A value of zero indicates an early termination of the table search in the root pointer (DT = page descriptor) if the level specification was not zero. If the level specification was zero, N is always set to zero.

#### **Instruction Format:**

| 15 | 14 | 13 | 12    | 11    | 10 | 9   | 8            | 7 | 6 | 5                 | 4    | 3 | 2 | 1       | 0 |  |
|----|----|----|-------|-------|----|-----|--------------|---|---|-------------------|------|---|---|---------|---|--|
| 1  | 1  | 1  | 1     | 0     | 0  | _   | 0            | _ | _ | EFFECTIVE ADDRESS |      |   |   |         |   |  |
| '  | '  | '  | '   ' | '   ' |    |     | 0            | " | " |                   | MODE |   | F | REGISTE | R |  |
| 1  | 0  | 0  |       | LEVEL |    | R/W | V A-REGISTER |   |   |                   |      | F | C |         |   |  |

## Get Information About Logical Address (MC68851)

### **PTEST**

#### **Instruction Fields:**

Effective Address field—Specifies the logical address about which information is requested. Only control alterable addressing modes can be used as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn                      | _    | _              |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | _    | _              |
| —(An)                   | _    | _              |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn] ,od)        | 110  | reg. number:An |
| ([bd,An],Xn ,od)        | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | _    | _        |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | _    | _        |
| (d <sub>8</sub> ,PC,Xn) | _    | _        |
| (bd,PC,Xn)              | _    | _        |
| ([bd,PC,Xn],od)         | _    | _        |
| ([bd,PC],Xn ,od)        | _    | _        |

#### **NOTE**

The effective address field must provide the MC68851 with the effective address of the logical address to be tested, not the effective address describing where the PTEST operand is located. For example, to test a logical address that is temporarily stored on the system stack, the instruction PTEST [(SP)] must be used since PTEST (SP) would test the mapping of the system stack (i.e., the effective address passed to the MC68851 is the effective address of the system stack, not the effective address formed by the operand located on the top of the stack).

## Get Information About Logical Address (MC68851)

**PTEST** 

Level field—Specifies the depth to which the translation table should be searched.

R/W field—Specifies whether the A-bit should be updated for a read or a write.

- 1—Read
- 0—Write
- A-Register field—Specifies the address register in which to load the last descriptor address.
  - 0xxx Do not return the last descriptor address to an address register.
  - 1RRR Return the last descriptor address to address register RRR.

#### **NOTE**

When the PTEST instruction specifies a level of zero, the A-register field must be 0000. Otherwise, an F-line exception is generated.

FC field—Function code of address to test.

- 1DDDD Function code is specified as four bits DDDD.
- 01RRR Function code is contained in CPU data register RRR.
- 00000 Function code is contained in CPU source function code register.
- 00001 Function code is contained in CPU destination function code register.

### **PTRAPcc**

## TRAP on PMMU Condition (M68851)

## **PTRAPcc**

**Operation:** If Supervisor State

Then If cc True
Then TRAP
Else TRAP

**Assembler** PTRAPcc

**Syntax:** PTRAPcc.W # < data > PTRAPcc.L # < data >

**Attributes:** Unsized or Size = (Word, Long)

**Description:** If the selected MC68851 condition is true, the processor initiates exception processing. The vector number is generated referencing the cpTRAPcc exception vector; the stacked program counter is the address of the next instruction. If the selected condition is not true, no operation is performed, and execution continues with the next instruction. The immediate data operand is placed in the next word(s) following the MC68851 condition and is available for user definition to be used within the trap handler. Following the condition word, there may be a user-defined data operand, specified as immediate data, to be used by the trap handler.

The condition specifier cc may specify the following conditions:

| Specifier | Description | Condition Field |
|-----------|-------------|-----------------|
| BS        | B set       | 000000          |
| LS        | L set       | 000010          |
| SS        | S set       | 000100          |
| AS        | A set       | 000110          |
| WS        | W set       | 001000          |
| IS        | I set       | 001010          |
| GS        | G set       | 001100          |
| CS        | C set       | 001110          |

| Specifier | Description | Condition Field |
|-----------|-------------|-----------------|
| ВС        | B clear     | 000001          |
| LC        | L clear     | 000011          |
| SC        | S clear     | 000101          |
| AC        | A clear     | 000111          |
| WC        | W clear     | 001001          |
| IC        | I clear     | 001011          |
| GC        | G clear     | 001101          |
| CC        | C clear     | 001111          |

PMMU Status Register: Not affected

### **PTRAPcc**

## TRAP on PMMU Condition (M68851)

## **PTRAPcc**

#### **Instruction Format:**

| 15 | 14                                                                   | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5                 | 4 | 3 | 2 | 2 1 0  |  |  |  |  |
|----|----------------------------------------------------------------------|----|----|----|----|---|---|---|---|-------------------|---|---|---|--------|--|--|--|--|
| 1  | 1                                                                    | 1  | 1  | 0  | 0  | 0 | 0 | 0 | 1 | 1                 | 1 | 1 |   | OPMODE |  |  |  |  |
| 0  | 0                                                                    | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | MC68851 CONDITION |   |   |   |        |  |  |  |  |
|    | 16-BIT OPERAND OR MOST SIGNIFICANT WORD OF 32-BIT OPERAND (IFNEEDED) |    |    |    |    |   |   |   |   |                   |   |   |   |        |  |  |  |  |
|    | LEAST SIGNIFICANT WORD OF 32-BIT OPERAND (IF NEEDED)                 |    |    |    |    |   |   |   |   |                   |   |   |   |        |  |  |  |  |

#### **Instruction Fields:**

Opmode field—Selects the instruction form.

010 — Instruction is followed by one operand word.

011 — Instruction is followed by two operand words.

100 — Instruction has no following operand words.

MC68851 Condition field—Specifies the coprocessor condition to be tested. This field is passed to the MC68851, which provides directives to the main processor for processing this instruction.

**PVALID** 

Validate a Pointer (MC68851)

**PVALID** 

**Operation:** If (Source AL Bits)  $\rightarrow$  (Destination AL Bits)

Then TRAP

**Assembler** PVALID VAL, < ea > **Syntax:** PVALID An, < ea >

**Attributes:** Size = (Long)

**Description:** The upper bits of the source, VAL or An, compare with the upper bits of the destination, < ea > . The ALC field of the access control register defines the number of bits compared. If the upper bits of the source are numerically greater than (less privileged than) the destination, they cause a memory management access level exception. Otherwise, execution continues with the next instruction. If the MC field of the access control register = 0, then this instruction always causes a paged memory management unit access level exception.

**PMMU Status Register:** Not affected.

#### **Instruction Format 1:**

VAL Contains Access Level to Test Against

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4    | 3       | 2        | 1  | 0 |  |
|----|----|----|----|----|----|---|---|---|---|---|------|---------|----------|----|---|--|
| 1  | 1  | 1  | 1  | 0  | 0  | 0 | 0 | 0 | 0 |   | EF   | FECTIVE | ADDRE    | SS |   |  |
| '  | '  | '  | '  | "  | "  | " | " | " | " |   | MODE |         | REGISTER |    |   |  |
| 0  | 0  | 1  | 0  | 1  | 0  | 0 | 0 | 0 | 0 | 0 | 0    | 0       | 0        | 0  | 0 |  |

### **PVALID**

## Validate a Pointer (MC68851)

### **PVALID**

#### **Instruction Field:**

Effective Address field—Specifies the logical address to be evaluated and compared against the valid access level register. Only control alterable addressing modes can be used as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn                      | _    | _              |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | _    | _              |
| —(An)                   | _    | _              |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn] ,od)        | 110  | reg. number:An |
| ([bd,An],Xn ,od)        | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | _    | _        |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | _    | _        |
| (d <sub>8</sub> ,PC,Xn) | _    | _        |
| (bd,PC,Xn)              | _    | _        |
| ([bd,PC,Xn] ,od)        | _    | _        |
| ([bd,PC],Xn ,od)        | _    | _        |

### **PVALID**

## Validate a Pointer (MC68851)

### **PVALID**

#### **Instruction Format 2:**

Main Processor Register Contains Access Level to Test Against

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4    | 3       | 2     | 1       | 0 |
|----|----|----|----|----|----|---|---|---|---|---|------|---------|-------|---------|---|
| 1  | 1  | 1  | 1  | 0  | 0  | _ | 0 | 0 | 0 |   | EFI  | FECTIVE | ADDRI | ESS     |   |
| ,  | '  | '  | '  | 0  | 0  | " | 0 | 0 | 0 |   | MODE |         | F     | REGISTE | R |
| 0  | 0  | 1  | 0  | 1  | 0  | 0 | 0 | 0 | 0 | 0 | 0    | 0       | F     | REGISTE | R |

#### Instruction Fields:

Effective Address field—Specifies the logical address to be evaluated and compared against specified main processor address register. Only control alterable addressing modes can be used as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn                      | _    | _              |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | _    | _              |
| —(An)                   | _    | _              |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |
| ([bd,An,Xn] ,od)        | 110  | reg. number:An |
| ([bd,An],Xn ,od)        | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | _    |          |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | _    |          |
| (d <sub>8</sub> ,PC,Xn) | _    | _        |
| (bd,PC,Xn)              | _    | _        |
| ([bd,PC,Xn] ,od)        | _    | _        |
| ([bd,PC],Xn ,od)        | _    | _        |

#### **NOTE**

The effective address field must provide the MC68851 with the effective address of the logical address to be validated, not the effective address describing where the PVALID operand is located. For example, to validate a logical address that is temporarily stored on the system stack, the instruction PVALID VAL,[(SP)] must be used since PVALID VAL,(SP) would validate the mapping on the system stack (i.e., the effective address passed to the MC68851 is the effective address of the system stack, not the effective address formed by the operand located on the top of the stack).

Register field—Specifies the main processor address register to be used in the compare.

RESET

## Reset External Devices (M68000 Family)

RESET

**Operation:** If Supervisor State

Then Assert RESET (RSTO, MC68040 Only) Line

Else TRAP

**Assembler** 

Syntax: RESET

Attributes: Unsized

**Description:** Asserts the RSTO signal for 512 (124 for MC68000, MC68EC000, MC68HC000, MC68HC001, MC68008, MC68010, and MC68302) clock periods, resetting all external devices. The processor state, other than the program counter, is unaffected, and execution continues with the next instruction.

#### **Condition Codes:**

Not affected.

#### **Instruction Format:**

|   | 14 |   |   |   |   | _ |   |   |   |   |   |   |   |   | _ |
|---|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 0 | 1  | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 |

RTE

## Return from Exception (M68000 Family)

**RTE** 

**Operation:** If Supervisor State

Then (SP)  $\rightarrow$  SR; SP + 2  $\rightarrow$  SP; (SP)  $\rightarrow$  PC; SP + 4  $\rightarrow$  SP; Restore

State and Deallocate Stack According to (SP)

Else TRAP

**Assembler** 

Syntax: RTE

Attributes: Unsized

**Description:** Loads the processor state information stored in the exception stack frame located at the top of the stack into the processor. The instruction examines the stack format field in the format/offset word to determine how much information must be restored.

#### **Condition Codes:**

Set according to the condition code bits in the status register value restored from the stack.

#### **Instruction Format:**

| _ |   | _ |   |   | - | - | _ |   | _ | _ |   | _ |   |   | 0 |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 0 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 1 |

#### Format/Offset Word (in Stack Frame):

MC68010, MC68020, MC68030, MC68040, CPU32

| 15 | 14  | 13  | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5      | 4     | 3 | 2 | 1 | 0 |
|----|-----|-----|----|----|----|---|---|---|---|--------|-------|---|---|---|---|
|    | FOR | MAT |    | 0  | 0  |   |   |   | \ | /ECTOR | OFFSE | l |   |   |   |

#### Format Field of Format/Offset Word:

Contains the format code, which implies the stack frame size (including the format/offset word). For further information, refer to **Appendix B Exception Processing Reference**.

STOP

#### Load Status Register and Stop (M68000 Family)

**STOP** 

**Operation:** If Supervisor State

Then Immediate Data → SR; STOP

Else TRAP

**Assembler** 

**Syntax:** STOP # < data >

Attributes: Unsized

**Description:** Moves the immediate operand into the status register (both user and supervisor portions), advances the program counter to point to the next instruction, and stops the fetching and executing of instructions. A trace, interrupt, or reset exception causes the processor to resume instruction execution. A trace exception occurs if instruction tracing is enabled (T0 = 1, T1 = 0) when the STOP instruction begins execution. If an interrupt request is asserted with a priority higher than the priority level set by the new status register value, an interrupt exception occurs; otherwise, the interrupt request is ignored. External reset always initiates reset exception processing.

#### **Condition Codes:**

Set according to the immediate operand.

#### **Instruction Format:**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8      | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|--------|---|---|---|---|---|---|---|---|
| 0  | 1  | 0  | 0  | 1  | 1  | 1 | 0      | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 0 |
|    |    |    |    |    |    | ı | MMEDIA |   | A |   |   |   |   |   |   |

#### Instruction Fields:

Immediate field—Specifies the data to be loaded into the status register.

# SECTION 7 CPU32 INSTRUCTIONS

This section describes the instructions provided for the CPU32. The CPU32 can execute object code from an MC68000 and MC68010 and many of the instructions of the MC68020.

There are three new instructions provided for the CPU32: enter background mode (BGND), low-power stop (LPSTOP), and table lookup and interpolate (TBLS, TBLSN, TBLU, and TBLUN). Table 7-1 lists the MC68020 instructions not supported by the CPU32.

Table 7-1. MC68020 Instructions Not Supported

| Mnemonic  | Description                                     |
|-----------|-------------------------------------------------|
| BFCHG     | Test Bit Field and Change                       |
| BFCLR     | Test Bit Field and Clear                        |
| BFEXTS    | Signed Bit Field Extract                        |
| BFEXTU    | Unsigned Bit Field Extract                      |
| BFFFO     | Bit Field Find First One                        |
| BFINS     | Bit Field Insert                                |
| BFSET     | Test Bit Field and Set                          |
| BFTST     | Test Bit Field                                  |
| CALLM     | CALL Module                                     |
| CAS       | Compare and Swap Operands                       |
| CAS2      | Compare and Swap Dual Operands                  |
| срВсс     | Branch on Coprocessor Condition                 |
| cpDBcc    | Test Coprocessor Condition Decrement and Branch |
| cpGEN     | Coprocessor General Function                    |
| cpRESTORE | Coprocessor Restore Function                    |
| cpSAVE    | Coprocessor Save Function                       |
| cpScc     | Set on Coprocessor Condition                    |
| cpTRAPcc  | Trap on Coprocessor Condition                   |
| RTM       | Return from Module                              |
| PACK      | Pack BCD                                        |
| UNPK      | Unpack BCD                                      |

Addressing in the CPU32 is register oriented. Most instructions allow the results of the specified operation to be placed either in a register or directly in memory. This flexibility eliminates the need for extra instructions to store register contents in memory. Table 7-2 lists the M68000 family addressing modes with cross-references to the MC68000, MC68010, CPU32, and MC68020. When referring to instructions in the previous sections, refer to Table 7-2 to identify the addressing modes available to the CPU32. Table 7-3 lists the instructions for the CPU32.

Table 7-2. M68000 Family Addressing Modes

| Addressing Mode                                           | Syntax                         | MC68000<br>MC68010 | CPU32 | MC68020 |
|-----------------------------------------------------------|--------------------------------|--------------------|-------|---------|
| Register Indirect                                         | Rn                             | X                  | Х     | Х       |
| Address Register Indirect                                 | (An)                           | X                  | Х     | Х       |
| Address Register Indirect with Postincrement              | (An) +                         | X                  | Х     | Х       |
| Address Register Indirect with Postdecrement              | – (An)                         | Х                  | Х     | Х       |
| Address Register Indirect with Displacement               | (d <sub>16</sub> ,An)          | Х                  | Х     | Х       |
| Address Register Indirect with Index (8-Bit Displacement) | (d <sub>8</sub> ,An,Xn)        | х                  | Х     | Х       |
| Address Register Indirect with Index (Base Displacement)  | (d <sub>8</sub> ,An,Xn*SCALE)  |                    | Х     | Х       |
| Memory Indirect with Postincrement                        | ([bd,An],Xn, od)               |                    |       | Х       |
| Memory Indirect with Preincrement                         | ([bd,An],Xn, od)               |                    |       | Х       |
| Absolute Short                                            | (xxx).W                        | Х                  | Х     | Х       |
| Absolute Long                                             | (xxx).L                        | Х                  | Х     | Х       |
| Program Counter Indirect with Displacement                | (d <sub>16</sub> ,PC)          | X                  | Х     | Х       |
| Program Counter Indirect with Index (8-Bit Displacement)  | (d <sub>8</sub> ,PC,Xn)        | х                  | Х     | Х       |
| Program Counter Indirect with Index (Base Displacement)   | (d <sub>8</sub> ,PC,Xn*SC ALE) |                    | Х     | Х       |
| Immediate                                                 | # < data >                     | Х                  | Х     | Х       |
| PC Memory Indirect with Postincrement                     | ([bd,PC],Xn, od)               |                    |       | Х       |
| PC Memory Indirect with Predecrement                      | ([bd,PC],Xn, od)               |                    |       | Х       |

NOTE: Xn,SIZE\*SCALE—Denotes index register n (data or address), the index size (W for word, L for long word and scale factor (1, 2, 4, or 8 for no-word, long-word, or 8 for quad- word scaling, respectively). X—Supported

### **Table 7-3. CPU32 Instruction Set**

| Mnemonic     | Description                                     |
|--------------|-------------------------------------------------|
| ABCD         | Add Decimal with Extend                         |
| ADD          | Add                                             |
| ADDA         | Add Address                                     |
| ADDI         | Add Immediate                                   |
| ADDQ         | Add Quick                                       |
| ADDX         | Add with Extend                                 |
| AND          | Logical AND                                     |
| ANDI         | Logical AND Immediate                           |
| ANDI to CCR  | AND Immediate to Condition Code                 |
| ANDI to SR   | Register AND Immediate to Status Register       |
| ASL, ASR     | Arithmetic Shift Left and Right                 |
|              |                                                 |
| Bcc          | Branch Conditionally                            |
| BCHG         | Test Bit and Change                             |
| BCLR<br>BGND | Test Bit and Clear                              |
| BKPT         | Enter Background Mode Breakpoint                |
| BRA          | Branch                                          |
| BSET         | Test Bit and Set                                |
| BSR          | Branch to Subroutine                            |
| BTST         | Test Bit                                        |
|              | Check Register Against Bound                    |
| CHK          | Check Register Against Upper and                |
| CHK2         | Lower Bound                                     |
| CLD          | Clear                                           |
| CLR<br>CMP   | Compare                                         |
| CMPA         | Compare Address                                 |
| CMPI         | Compare Immediate                               |
| CMPM         | Compare Memory to Memory                        |
| CMP2         | Compare Register Against Upper and Lower Bounds |
|              | Lower Bourius                                   |
|              |                                                 |
| DBcc         | Test Condition, Decrement, and                  |
|              | Branch                                          |
| DIVS, DIVSL  | Signed Divide                                   |
| DIVU, DIVUL  | Unsigned Divide                                 |
|              |                                                 |
| EOR          | Logical Exclusive-OR                            |
| FORI         | Logical Exclusive-OR Immediate                  |
| EORI to CCR  | Exclusive-OR Immediate to                       |
|              | Condition Code Register                         |
| EORI to SR   | Exclusive-OR Immediate to                       |
|              | Status Register                                 |
| EXG          | Exchange Registers                              |
| EXT, LSR     | Sign-Extend                                     |
| ILLEGAL      | Take Illegal Instruction Trap                   |
| JMP<br>JSR   | Jump Jump to Subroutine                         |
| LEA          | Load Effective Address                          |
| LINK         | Link and Allocate                               |
| LPSTOP       | Low Power Stop                                  |
| LSL, LSR     | Logical Shift Left and Right                    |
| , <b></b>    | - 3                                             |

| Mnemonic                                                                                          | Description                                                                                                                                                                                                                                                      |
|---------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MOVE MOVEA MOVE from CCR Move from SR MOVE to SR MOVE USP MOVEC MOVEM MOVEP MOVEQ MOVES MULS MULU | Move Move Address Move Condition Code Register Move from Status Register Move to Status Register Move User Stack Pointer Move Control Register Move Multiple Registers Move Peripheral Move Quick Move Alternate Address Space Signed Multiply Unsigned Multiply |
| NBCD<br>NEG<br>NEGX<br>NOP<br>NOT                                                                 | Negate Decimal with Extend<br>Negate<br>Negate with Extend<br>No Operation<br>Logical Complement                                                                                                                                                                 |
| PEA                                                                                               | Push Effective Address                                                                                                                                                                                                                                           |
| RESET<br>ROL, ROR<br>ROXL, ROXR<br>RTD<br>RTE<br>RTR<br>RTS                                       | Reset External Devices Rotate Left and Right Rotate with Extend Left and Right Return and Deallocate Return from Exception Return and Restore Codes Return from Subroutine                                                                                       |
| SBCD<br>Scc<br>STOP<br>SUB<br>SUBA<br>SUBI<br>SUBQ<br>SUBX<br>SWAP                                | Subtract Decimal with Extend Set Conditionally Stop Subtract Subtract Address Subtract Immediate Subtract Quick Subtract with Extend Swap Register Words                                                                                                         |
| TAS TBLS, TBLSN  TBLU, TBLUN  TRAP TRAPcc TRAPV TST                                               | Test Operand and Set Signed/Unsigned Table Lookup and Interpolate Signed/Unsigned Table Lookup and Interpolate Trap Trap Conditionally Trap an Overflow Test Operand                                                                                             |
| UNLK                                                                                              | Unlink                                                                                                                                                                                                                                                           |

**BGND** 

# Enter Background Mode (CPU32)

**BGND** 

**Operation:** If Background Mode Enabled

Then Enter Background Mode Else Format/Vector Offset  $\rightarrow$  – (SSP);

 $PC \rightarrow - (SSP)$   $SR \rightarrow - (SSP)$  $(Vector) \rightarrow PC$ 

**Assembler** 

Syntax: BGND

**Attributes:** Size = (Unsized)

**Description:** The processor suspends instruction execution and enters background mode if background mode is enabled. The freeze output is asserted to acknowledge entrance into background mode. Upon exiting background mode, instruction execution continues with the instruction pointed to by the current program counter. If background mode is not enabled, the processor initiates illegal instruction exception processing. The vector number is generated to reference the illegal instruction exception vector. Refer to the appropriate user's manual for detailed information on background mode.

#### **Condition Codes:**

| Χ | Ν | Z | V | С |
|---|---|---|---|---|
| _ | _ | _ | _ | _ |

X — Not affected.

N — Not affected.

Z — Not affected.

V — Not affected.

C — Not affected.

#### **Instruction Format:**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0  | 1  | 0  | 0  | 1  | 0  | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 0 |

## **LPSTOP**

#### Low-Power Stop (CPU32)

**LPSTOP** 

**Operation:** If Supervisor State

Immediate Data → SR

Interrupt Mask → External Bus Interface (EBI)

STOP Else TRAP

Assembler

**Syntax:** LPSTOP # < data >

**Attributes:** Size = (Word) Privileged

**Description:** The immediate operand moves into the entire status register, the program counter advances to point to the next instruction, and the processor stops fetching and executing instructions. A CPU LPSTOP broadcast cycle is executed to CPU space \$3 to copy the updated interrupt mask to the external bus interface (EBI). The internal clocks are stopped.

Instruction execution resumes when a trace, interrupt, or reset exception occurs. A trace exception will occur if the trace state is on when the LPSTOP instruction is executed. If an interrupt request is asserted with a higher priority that the current priority level set by the new status register value, an interrupt exception occurs; otherwise, the interrupt request is ignored. If the bit of the immediate data corresponding to the S-bit is off, execution of the instruction will cause a privilege violation. An external reset always initiates reset exception processing.

#### **Condition Codes:**

Set according to the immediate operand.

#### **Instruction Format:**

| 15 | 14             | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----------------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1              | 1  | 1  | 1  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 0  | 0              | 0  | 0  | 0  | 0  | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 |
|    | IMMEDIATE DATA |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

#### Instruction Fields:

Immediate field—Specifies the data to be loaded into the status register.

#### Table Lookup and Interpolate (Signed) (CPU32)

**TBLS TBLSN** 

**Operation:** Rounded:

ENTRY(n) + { $(ENTRY(n + 1) - ENTRY(n)) \times Dx 7 - 0$ } ÷ 256  $\rightarrow Dx$ 

Unrounded:

ENTRY(n) x 256 + {(ENTRY(n + 1) – ENTRY(n)) x Dx 7 – 0}  $\rightarrow$  Dx

Where ENTRY(n) and ENTRY(n + 1) are either:

1. Consecutive entries in the table pointed to by the < ea > and

indexed by Dx 15 – 8  $\pi$  SIZE or;

2. The registers Dym, Dyn respectively.

**Assembler** TBLS. < size > < ea > ,Dx Syntax:

Result rounded

TBLSN. < size > < ea > .Dx

Result not rounded

TBLS. < size > Dym:Dyn, Dx TBLSN. < size > Dym:Dyn, Dx Result rounded

Result not rounded

Attributes: Size = (Byte, Word, Long)

**Description:** The TBLS and TBLSN instructions allow the efficient use of piecewise linear compressed data tables to model complex functions. The TBLS instruction has two modes of operation: table lookup and interpolate mode and data register interpolate mode.

For table lookup and interpolate mode, data register Dx 15 - 0 contains the independent variable X. The effective address points to the start of a signed byte, word, or long-word table containing a linearized representation of the dependent variable, Y, as a function of X. In general, the independent variable, located in the low-order word of Dx, consists of an 8-bit integer part and an 8-bit fractional part. An assumed radix point is located between bits 7 and 8. The integer part, Dx 15 – 8, is scaled by the operand size and is used as an offset into the table. The selected entry in the table is subtracted from the next consecutive entry. A fractional portion of this difference is taken by multiplying by the interpolation fraction, Dx 7 - 0. The adjusted difference is then added to the selected table entry. The result is returned in the destination data register, Dx.

## Table Lookup and Interpolate (Signed) (CPU32)

## TBLS TBLSN

For register interpolate mode, the interpolation occurs using the Dym and Dyn registers in place of the two table entries. For this mode, only the fractional portion, Dx 7-0, is used in the interpolation, and the integer portion, Dx 15-8, is ignored. The register interpolation mode may be used with several table lookup and interpolations to model multidimensional functions.

Signed table entries range from  $-2^{n-1}$  to  $2^{n-1}-1$ ; whereas, unsigned table entries range from 0 to  $2^{n-1}$  where n is 8, 16, or 32 for byte, word, and long-word tables, respectively.

Rounding of the result is optionally selected via the "R" instruction field. If R=0 (TABLE), the fractional portion is rounded according to the round-to-nearest algorithm. The following table summerizes the rounding procedure:

| Adjusted Difference<br>Fraction | Rounding<br>Adjustment |
|---------------------------------|------------------------|
| ≤ − 1/2                         | <b>–</b> 1             |
| > - 1/2 and < 1/2               | + 0                    |
| ≥ 1/2                           | + 1                    |

The adjusted difference is then added to the selected table entry. The rounded result is returned in the destination data register, Dx. Only the portion of the register corresponding to the selected size is affected.

|      | 31       | 24 | 23     | 16   | 15    | 8     | 7  | 0    |
|------|----------|----|--------|------|-------|-------|----|------|
| BYTE | UNAFFECT | ED | UNAFFE | CTED | UNAFF | ECTED | RE | SULT |
| WORD | UNAFFECT | ED | UNAFFE | CTED | RES   | SULT  | RE | SULT |
| LONG | RESULT   |    | RESU   | JLT  | RES   | ULT   | RE | SULT |

## Table Lookup and Interpolate (Signed) (CPU32)

TBLS TBLSN

If R = 1 (TABLENR), the result is returned in register Dx without rounding. If the size is byte, the integer portion of the result is returned in Dx 15 - 8; the integer portion of a word result is stored in Dx 23 - 8; the least significant 24 bits of a long result are stored in Dx 31 - 8. Byte and word results are sign-extended to fill the entire 32-bit register.

|      | 31 24         | 23      | 16     | 15  | 8    | 7   | 0      |
|------|---------------|---------|--------|-----|------|-----|--------|
| BYTE | SIGN-EXTENDED | SIGN-EX | TENDED | RES | SULT | FRA | ACTION |
| WORD | SIGN-EXTENDED | RES     | SULT   | RES | SULT | FRA | ACTION |
| LONG | RESULT        | RES     | SULT   | RES | SULT | FRA | ACTION |

#### **NOTE**

The long-word result contains only the least significant 24 bits of integer precision.

For all sizes, the 8-bit fractional portion of the result is returned to the low byte of the data register, Dx 7 - 0. User software can make use of the fractional data to reduce cumulative errors in lengthy calculations or implement rounding algorithms different from that provided by other forms of TBLS. The previously described assumed radix point places two restrictions on the programmer:

- 1. Tables are limited to 257 entries in length.
- 2. Interpolation resolution is limited to 1/256, the distance between consecutive table entries. The assumed radix point should not, however, be construed by the programmer as a requirement that the independent variable be calculated as a fractional number in the range  $0 < \pi < 255$ . On the contrary, X should be considered an integer in the range  $0 < \pi < 65535$ , realizing that the table is actually a compressed representation of a linearized function in which only every 256th value is actually stored in memory.

# Table Lookup and Interpolate (Signed) (CPU32)

## TBLS TBLSN

#### **Condition Codes:**

| Χ | Ν | Z | V | С |
|---|---|---|---|---|
| _ | * | * | * | 0 |

X — Not affected.

N — Set if the most significant bit of the result is set; cleared otherwise.

Z — Set if the result is zero; cleared otherwise.

V — Set if the integer portion of an unrounded long result is not in the range,  $-(2^{23})$   $\leq$  Result  $\leq (2^{23}) - 1$ ; cleared otherwise.

C — Always cleared.

#### **Instruction Format:**

#### TABLE LOOKUP AND INTERPOLATE

|   | 15 | 14 | 13     | 12 | 11 | 10 | 9 | 8 | 7  | 6  | 5 | 4    | 3       | 2     | 1      | 0 |
|---|----|----|--------|----|----|----|---|---|----|----|---|------|---------|-------|--------|---|
| ſ | 1  | 1  | 1      | 4  | 4  | 0  | 0 | 0 | 0  | 0  |   | EF   | FECTIVE | ADDRE | SS     |   |
|   | '  | '  | '      | '  | '  | "  | " | " | 0  | "  |   | MODE |         | R     | EGISTE | R |
| Ī | 0  | RE | GISTER | Dx | 1  | R  | 0 | 1 | SI | ZE | 0 | 0    | 0       | 0     | 0      | 0 |

#### DATA REGISTER INTERPOLATE

| 15 | 14 | 13     | 12 | 11 | 10 | 9 | 8 | 7    | 6 | 5 | 4 | 3 | 2   | 1      | 0   |
|----|----|--------|----|----|----|---|---|------|---|---|---|---|-----|--------|-----|
| 1  | 1  | 1      | 1  | 1  | 0  | 0 | 0 | 0    | 0 | 0 | 0 | 0 | REC | SISTER | Dym |
| 0  | RE | GISTER | Dx | 1  | R  | 0 | 1 | SIZE |   | 0 | 0 | 0 | REC | SISTER | Dyn |

## Table Lookup and Interpolate (Signed) (CPU32)

## TBLS TBLSN

#### **Instruction Fields:**

Effective address field (table lookup and interpolate mode only)—Specifies the destination location. Only control alterable addressing modes are allowed as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn                      | _    | _              |
| An                      | _    | _              |
| (An)                    | _    | _              |
| (An) +                  | _    | _              |
| – (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | _    | _        |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |

Size Field—Specifies the size of operation.

00 — Byte Operation

01 — Word Operation

10 — Long Operation

Register field—Specifies the destination data register, Dx. On entry, the register contains the interpolation fraction and entry number.

Dym, Dyn field—If the effective address mode field is nonzero, this operand register is unused and should be zero. If the effective address mode field is zero, the surface interpolation variant of this instruction is implied, and Dyn specifies one of the two source operands.

Rounding mode field—The R-bit controls the rounding of the final result. When R = 0, the result is rounded according to the round-to-nearest algorithm. When R = 1, the result is returned unrounded.

## TBLU TBLUN

## Table Lookup and Interpolation (Unsigned) (CPU32)

TBLU TBLUN

**Operation:** Rounded:

 $\mathsf{ENTRY}(\mathsf{n}) + \{(\mathsf{ENTRY}(\mathsf{n}+1) - \mathsf{ENTRY}(\mathsf{n})) \ \mathsf{x} \ \mathsf{Dx} \ \mathsf{7} - \mathsf{0}\} \div \mathsf{256} \to \mathsf{Dx}$ 

Unrounded:

 $ENTRY(n) \times 256 + \{(ENTRY(n + 1) - ENTRY(n)) \times Dx \cdot 7 - 0\} \rightarrow Dx$ 

Where ENTRY(n) and ENTRY(n + 1) are either:

1. Consecutive entries in the table pointed to by the < ea > and

indexed by Dx 15 – 8  $\pi$  SIZE or;

2. The registers Dym, Dyn respectively

Assembler Syntax:

TBLU. < size > < ea > ,Dx

TBLUN. < size > < ea > ,Dx

Result rounded

Result not rounded

Result rounded

Result rounded

Result rounded

Result rounded

Result rounded

**Attributes:** Size = (Byte, Word, Long)

**Description:** The TBLU and TBLUN instructions allow the efficient use of piecewise linear, compressed data tables to model complex functions. The TBLU instruction has two modes of operation: table lookup and interpolate mode and data register interpolate mode.

For table lookup and interpolate mode, data register Dx 15-0 contains the independent variable X. The effective address points to the start of a unsigned byte, word, or long-word table containing a linearized representation of the dependent variable, Y, as a function of X. In general, the independent variable, located in the low-order word of Dx, consists of an 8-bit integer part and an 8-bit fractional part. An assumed radix point is located between bits 7 and 8. The integer part, Dx 15-8, is scaled by the operand size and is used as an offset into the table. The selected entry in the table is subtracted from the next consecutive entry. A fractional portion of this difference is taken by multiplying by the interpolation fraction, Dx 7-0. The adjusted difference is then added to the selected table entry. The result is returned in the destination data register, Dx.

### **TBLUN** Table Lookup and Interpolation (Unsigned) (CPU32)



For register interpolate mode, the interpolation occurs using the Dym and Dyn registers in place of the two table entries. For this mode, only the fractional portion, Dx 7-0, is used in the interpolation and the integer portion, Dx 15 - 8, is ignored. The register interpolation mode may be used with several table lookup and interpolations to model multidimensional functions.

Signed table entries range from  $-2^{n-1}$  to  $2^{n-1}-1$ ; whereas, unsigned table entries range from 0 to 2<sup>n-1</sup> where n is 8, 16, or 32 for byte, word, and long-word tables, respectively. The unsigned and unrounded table results will be zero-extended instead of sign-extended.

Rounding of the result is optionally selected via the "R" instruction field. If R = 0 (TABLE), the fractional portion is rounded according to the round-to-nearest algorithm. The rounding procedure can be summarized by the following table:

| Adjusted Difference<br>Fraction | Rounding<br>Adjustme<br>nt |
|---------------------------------|----------------------------|
| ≥ 1/2                           | + 1                        |
| < 1/2                           | + 0                        |

The adjusted difference is then added to the selected table entry. The rounded result is returned in the destination data register, Dx. Only the portion of the register corresponding to the selected size is affected.

|      | 31        | 24 23 | 16        | 15    | 8      | 7     | 0  |
|------|-----------|-------|-----------|-------|--------|-------|----|
| BYTE | UNAFFECTE | D U   | NAFFECTED | UNAFI | FECTED | RESUL | .T |
| WORD | UNAFFECTE | D U   | NAFFECTED | RE    | SULT   | RESUL | .Т |
| LONG | RESULT    |       | RESULT    | RE    | SULT   | RESUL | .T |

If R = 1 (TBLUN), the result is returned in register Dx without rounding. If the size is byte, the integer portion of the result is returned in Dx 15 – 8; the integer portion of a word result is stored in Dx 23 – 8; the least significant 24 bits of a long result are stored in Dx 31 – 8. Byte and word results are sign-extended to fill the entire 32-bit register.

## **TBLUN** Table Lookup and Interpolation (Unsigned) (CPU32)



|      | 31 24         | 23      | 16      | 15  | 8    | 7   | 0     |
|------|---------------|---------|---------|-----|------|-----|-------|
| BYTE | SIGN-EXTENDED | SIGN-EX | KTENDED | RES | SULT | FRA | CTION |
| WORD | SIGN-EXTENDED | RES     | SULT    | RES | SULT | FRA | CTION |
| LONG | RESULT        | RES     | SULT    | RES | SULT | FRA | CTION |

#### **NOTE**

The long-word result contains only the least significant 24 bits of integer precision.

For all sizes, the 8-bit fractional portion of the result is returned in the low byte of the data register, Dx 7 – 0. User software can make use of the fractional data to reduce cumulative errors in lengthy calculations or implement rounding algorithms different from that provided by other forms of TBLU. The previously described assumed radix point places two restrictions on the programmer:

- 1. Tables are limited to 257 entries in length.
- 2. Interpolation resolution is limited to 1/256, the distance between consecutive table entries. The assumed radix point should not, however, be construed by the programmer as a requirement that the independent variable be calculated as a fractional number in the range  $0 \le X \le 255$ . On the contrary, X should be considered to be an integer in the range  $0 \le X \le 65535$ , realizing that the table is actually a compressed representation of a linearized function in which only every 256th value is actually stored in memory.

#### **Condition Codes:**

| X | N | Z | V | С |
|---|---|---|---|---|
| _ | * | * | * | 0 |

- X Not affected.
- N Set if the most significant bit of the result is set; cleared otherwise.
- Z Set if the result is zero; cleared otherwise.
- V Set if the integer portion of an unrounded long result is not in the range,  $-(2^{23})$  $\leq$  Result  $\leq$  (2<sup>23</sup>) – 1; cleared otherwise.
- C Always cleared.

## TBLUN Table Lookup and Interpolation (Unsigned) (CPU32)

## **TBLU TBLUN**

#### **Instruction Format:**

#### TABLE LOOKUP AND INTERPOLATE

| 15 | 14 | 13     | 12 | 11 | 10 | 9 | 8 | 7    | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|----|--------|----|----|----|---|---|------|---|---|------|---------|-------|--------|---|
| 1  | 1  | 1      | 1  | 1  | 0  | 0 | 0 | 0    | 0 |   | EFI  | FECTIVE | ADDRE | SS     |   |
| '  | '  | '      | '  | '  |    | " | " |      |   |   | MODE |         | R     | EGISTE | R |
| 0  | RE | GISTER | Dx | 0  | R  | 0 | 1 | SIZE | 0 | 0 | 0    | 0       | 0     | 0      | 0 |

#### DATA REGISTER INTERPOLATE

| 15 | 14          | 13 | 12 | 11 | 10 | 9 | 8 | 7    | 6 | 5 | 4 | 3 | 2   | 1            | 0   |
|----|-------------|----|----|----|----|---|---|------|---|---|---|---|-----|--------------|-----|
| 1  | 1           | 1  | 1  | 1  | 0  | 0 | 0 | 0    | 0 | 0 | 0 | 0 | REC | REGISTER Dym |     |
| 0  | REGISTER Dx |    |    | 0  | R  | 0 | 0 | SIZE |   | 0 | 0 | 0 | REC | SISTER       | Dyn |

#### **Instruction Fields:**

Effective address field (table lookup and interpolate mode only)—Specifies the destination location. Only control alterable addressing modes are allowed as listed in the following table:

| Addressing Mode         | Mode | Register       |
|-------------------------|------|----------------|
| Dn                      | _    | _              |
| An                      | _    | _              |
| (An)                    | 010  | reg. number:An |
| (An) +                  | _    | _              |
| – (An)                  | 100  | reg. number:An |
| (d <sub>16</sub> ,An)   | 101  | reg. number:An |
| (d <sub>8</sub> ,An,Xn) | 110  | reg. number:An |
| (bd,An,Xn)              | 110  | reg. number:An |

| Addressing Mode         | Mode | Register |
|-------------------------|------|----------|
| (xxx).W                 | 111  | 000      |
| (xxx).L                 | 111  | 001      |
| # < data >              | _    |          |
|                         |      |          |
|                         |      |          |
| (d <sub>16</sub> ,PC)   | 111  | 010      |
| (d <sub>8</sub> ,PC,Xn) | 111  | 011      |
| (bd,PC,Xn)              | 111  | 011      |

Size field—Specifies the size of operation.

00 — Byte Operation

01 — Word Operation

10 — Long Operation

## TBLUN Table Lookup and Interpolation (Unsigned) (CPU32)



Register field—Specifies the destination data register, Dx. On entry, the register contains the interpolation fraction and entry number.

Dym, Dyn field—If the effective address mode field is nonzero, this operand register is unused and should be zero. If the effective address mode field is zero, the surface interpolation variant of this instruction is implied, and Dyn specifies one of the two source operands.

Rounding mode field—The R-bit controls the rounding of the final result. When R = 0, the result is rounded according to the round-to-nearest algorithm. When R = 1, the result is returned unrounded.

# SECTION 8 INSTRUCTION FORMAT SUMMARY

This section contains a listing of the M68000 family instructions in binary format. It is listed in opcode order for the M68000 family instruction set.

#### 8.1 INSTRUCTION FORMAT

The following paragraphs present a summary of the binary encoding fields.

#### 8.1.1 Coprocessor ID Field

This field specifies which coprocessor in a system is to perform the operation. When using directly supported floating-point instructions for the MC68040, this field must be set to one.

#### 8.1.2 Effective Address Field

This field specifies which addressing mode is to be used. For some operations, there are hardware-enforced restrictions on the available addressing modes allowed.

#### 8.1.3 Register/Memory Field

This field is common to all arithmetic instructions. A zero in this field indicates a register-to-register operation, and a one indicates an < ea > -to-register operation.

#### 8.1.4 Source Specifier Field

This field is common to all artihmetic instructions. The value of the register/memory (R/M) field affects this field,s definition. If R/M = 0, specifies the source floating-point data register (FPDR). If R/M = 1, specifies the source operand data format.

- 000 Long-Word Integer (L)
- 001 Single-Precision Real (S)
- 010 Extended-Precision Real (X)
- 011 Packed-Decimal Real (P)
- 100 Word Integer (W)
- 101 Double-Precision Real (D)
- 110 Byte Integer (B)

#### 8.1.5 Destination Register Field

This field is common to all arithmetic instructions. It specifies the FPDR that that will be the destination. The results are always stored in this register.

#### 8.1.6 Conditional Predicate Field

This field is common to all conditional instructions and specifies the conditional test that is to be evaluated. Table 8-1 shows the binary encodings for the conditional tests.

#### 8.1.7 Shift and Rotate Instructions

The following paragraphs define the fields used with the shift and rotate instructions.

**8.1.7.1 Count Register Field.** If i/r = 0, this field contains the rotate (shift) count of 1 - 8 (a zero specifies 8). If i/r = 1, this field specifies a data register that contains the rotate (shift) count. The following shift and rotate fields are encoded as follows:

```
dr field
0 — Rotate (shift) Right
1 — Rotate (shift) Left

i/r field
0 — Immediate Rotate (shift) Count
1 — Register Rotate (shift) Count
```

**8.1.7.2 Register Field.** This field specifies a data register to be rotated (shifted).

**MOTOROLA** 

**Table 8-1. Conditional Predicate Field Encoding** 

| Conditional Predicate | Mnemonic | Definition                               |
|-----------------------|----------|------------------------------------------|
| 000000                | F        | False                                    |
| 000001                | EQ       | Equal                                    |
| 000010                | OGT      | Ordered Greater Than                     |
| 000011                | OGE      | Ordered Greater Than or Equal            |
| 000100                | OLT      | Ordered Less Than                        |
| 000101                | OLE      | Ordered Less Than or Equal               |
| 000110                | OGL      | Ordered Greater Than or Less Than        |
| 000111                | OR       | Ordered                                  |
| 001000                | UN       | Unordered                                |
| 001001                | UEQ      | Unordered or Equal                       |
| 001010                | UGT      | Unordered or Greater Than                |
| 001011                | UGE      | Unordered or Greater Than or Equal       |
| 001100                | ULT      | Unordered or Less Than                   |
| 001101                | ULE      | Unordered or Less Than or Equal          |
| 001110                | NE       | Not Equal                                |
| 001111                | Т        | True                                     |
| 010000                | SF       | Signaling False                          |
| 010001                | SEQ      | Signaling Equal                          |
| 010010                | GT       | Greater Than                             |
| 010011                | GE       | Greater Than or Equal                    |
| 010100                | LT       | Less Than                                |
| 010101                | LE       | Less Than or Equal                       |
| 010110                | GL       | Greater Than or Less Than                |
| 010111                | GLE      | Greater Than or Less Than or Equal       |
| 011000                | NGLE     | Not (Greater Than or Less Than or Equal) |
| 011001                | NGL      | Not (Greater Than or Less Than)          |
| 011010                | NLE      | Not (Less Than or Equal)                 |
| 011011                | NLT      | Not (Less Than)                          |
| 011100                | NGE      | Not (Greater Than or Equal)              |
| 011101                | NGT      | Not (Greater Than)                       |
| 011110                | SNE      | Signaling Not Equal                      |
| 011111                | ST       | Signaling True                           |

#### 8.1.8 Size Field

This field specifies the size of the operation. The encoding is as follows:

00 — Byte Operation

01 — Word Operation

10 — Long Operation

#### 8.1.9 Opmode Field

Refer to the applicable instruction descriptions for the encoding of this field in Section 4 Integer Instructions, Section 5 Floating Point Instructions, Section 6 Supervisor (Privaleged) Instructions, and Section 7 CPU32 Instructions.

#### 8.1.10 Address/Data Field

This field specifies the type of general register. The encoding is:

1111

0 — Data Register

1 — Address Register

#### **8.2 OPERATION CODE MAP**

Table 8-2 lists the encoding for bits 15 – 12 and the operation performed.

Bits 15 - 12 Operation 0000 Bit Manipulation/MOVEP/Immed iate 0001 Move Byte 0010 Move Long Move Word 0011 0100 Miscellaneous 0101 ADDQ/SUBQ/Scc/DBcc/TRAPc c 0110 Bcc/BSR/BRA 0111 MOVEQ 1000 OR/DIV/SBCD 1001 SUB/SUBX 1010 (Unassigned, Reserved) 1011 CMP/EOR 1100 AND/MUL/ABCD/EXG 1101 ADD/ADDX 1110 Shift/Rotate/Bit Field

**Table 8-2. Operation Code Map** 

CPU32 Extensions

Coprocessor Interface/MC68040 and

#### **ORI to CCR**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4        | 3       | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|----------|---------|---|---|---|
| 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 1 | 1        | 1       | 1 | 0 | 0 |
| 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 |   |   |   | 8-BIT BY | TE DATA | Ą | - |   |

#### **ORI to SR**

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8       | 7      | 6  | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|----|---------|--------|----|---|---|---|---|---|---|
| 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0       | 0      | 1  | 1 | 1 | 1 | 1 | 0 | 0 |
|    |    | •  |    |    |    | 16 | 6-BIT W | ORD DA | ΓA |   |   |   |   |   |   |

#### ORI

| 15 | 14 | 13 | 12       | 11     | 10 | 9 | 8        | 7      | 6      | 5 | 4        | 3       | 2   | 1      | 0     |    |  |
|----|----|----|----------|--------|----|---|----------|--------|--------|---|----------|---------|-----|--------|-------|----|--|
| 0  | 0  |    |          | _      | _  | _ |          | CI.    | SIZE   |   | SIZE     |         | EFF | ECTIVE | ADDRE | SS |  |
| 0  | U  | "  | "        | 0      | "  | " | "        | ا ا    | EGISTE | R |          |         |     |        |       |    |  |
|    |    | 16 | 6-BIT WO | ORD DA | ГА |   |          |        |        |   | 8-BIT BY | TE DATA | 4   |        |       |    |  |
|    |    |    |          |        |    | 3 | 2-BIT LC | NG DAT | Ā      |   |          |         |     |        |       |    |  |

#### **ANDI to CCR**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4        | 3       | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|----------|---------|---|---|---|
| 0  | 0  | 0  | 0  | 0  | 0  | 1 | 0 | 0 | 0 | 1 | 1        | 1       | 1 | 0 | 0 |
| 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 |   |   |   | 8-BIT BY | TE DATA | A | - |   |

#### **ANDI to SR**

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8        | 7      | 6  | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|----|----------|--------|----|---|---|---|---|---|---|
| 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0        | 0      | 1  | 1 | 1 | 1 | 1 | 0 | 0 |
|    |    |    |    |    |    | 16 | 6-BIT WO | ORD DA | ΤA |   |   |   |   |   |   |

#### **ANDI**

| 15 | 14 | 13 | 12       | 11               | 10 | 9 | 8 | 7   | 6          | 5                 | 4    | 3 | 2 | 1       | 0 |  |
|----|----|----|----------|------------------|----|---|---|-----|------------|-------------------|------|---|---|---------|---|--|
| 0  | 0  | _  | 0        | 0                | _  | 0 | _ | SI  | 70         | EFFECTIVE ADDRESS |      |   |   |         |   |  |
| "  | 0  | "  | "        | U                | "  | 0 | 0 | 31. | <b>4</b> E |                   | MODE |   | F | REGISTE | R |  |
|    |    | 16 | 6-BIT WO | ORD DAT          | ΓA |   |   |     |            | 8-BIT BYTE DATA   |      |   |   |         |   |  |
|    |    |    |          | 32-BIT LONG DATA |    |   |   |     |            |                   |      |   |   |         |   |  |

#### **SUBI**

| 15 | 14 | 13 | 12       | 11     | 10 | 9 | 8        | 7      | 6  | 5                 | 4        | 3       | 2 | 1 | 0 |
|----|----|----|----------|--------|----|---|----------|--------|----|-------------------|----------|---------|---|---|---|
| 0  | 0  | _  | _        | _      | 1  | _ | _        | SI     | 75 | EFFECTIVE ADDRESS |          |         |   |   |   |
| "  | "  | "  | "        | "      | '  | " | 0        | 31,    | ZL | MODE REGISTER     |          |         |   | R |   |
|    | •  | 16 | 6-BIT WO | ORD DA | ΓA | • | •        |        |    | 8                 | 3-BIT BY | TE DATA | 4 |   |   |
|    |    |    |          |        |    | 3 | 2-BIT LC | NG DAT | Ā  |                   |          |         |   |   |   |

#### **RTM**

|   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3   | 2 | 1      | 0 |
|---|----|----|----|----|----|----|---|---|---|---|---|---|-----|---|--------|---|
| ſ | 0  | 0  | 0  | 0  | 0  | 1  | 1 | 0 | 1 | 1 | 0 | 0 | D/A | R | EGISTE | R |

#### **CALLM**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4      | 3      | 2     | 1       | 0 |
|----|----|----|----|----|----|---|---|---|---|---|--------|--------|-------|---------|---|
| 0  | 0  | 0  | _  | 0  | 1  | 1 | 0 | 1 | 1 |   | EFF    | ECTIVE | ADDRE | ESS     |   |
| 0  | "  | "  | "  | "  | '  | ' | " | ' | ' |   | MODE   |        | F     | REGISTE | R |
| 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 |   |   | Α | RGUMEN | IT COU | NT    |         |   |

#### **ADDI**

| 15 | 14 | 13 | 12       | 11      | 10 | 9 | 8        | 7      | 6   | 5                 | 4        | 3       | 2 | 1      | 0 |
|----|----|----|----------|---------|----|---|----------|--------|-----|-------------------|----------|---------|---|--------|---|
|    | 0  | _  | _        | 0       | 1  | 1 | 0        | Q1     | ZE  | EFFECTIVE ADDRESS |          |         |   | ESS    |   |
| "  | "  | "  | 0        |         | '  | ' |          | 31.    | Z L |                   | MODE     |         | R | EGISTE | R |
|    | -  | 16 | 6-BIT WO | ORD DAT | ΓA | - | -        |        |     |                   | 8-BIT BY | TE DATA | Ą |        |   |
|    |    |    |          |         |    | 3 | 2-BIT LC | NG DAT | Ā   |                   |          |         |   |        |   |

#### CMP2

| 15  | 14 | 13     | 12 | 11 | 10  | 9          | 8 | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|-----|----|--------|----|----|-----|------------|---|---|---|---|------|---------|-------|--------|---|
| 0   |    | _      | _  | _  | CI. | ZE         | _ | 4 | 1 |   | EFI  | FECTIVE | ADDRE | ESS    |   |
| U   | "  | 0      | "  | "  | 31. | <b>Z</b> E | " | ' | ' |   | MODE |         | R     | EGISTE | R |
| D/A | R  | EGISTE | R  | 0  | 0   | 0          | 0 | 0 | 0 | 0 | 0    | 0       | 0     | 0      | 0 |

#### CHK2

| 15  | 14 | 13     | 12 | 11 | 10  | 9        | 8 | 7 | 6 | 5                | 4    | 3 | 2   | 1      | 0 |
|-----|----|--------|----|----|-----|----------|---|---|---|------------------|------|---|-----|--------|---|
| 0   | 0  | 0      | 0  | 0  | Q1  | ZE       | 0 | 1 | 1 | EFFECTIVE ADDRES |      |   | ESS |        |   |
| U   | 0  |        |    | 0  | JI. | <u> </u> | " | ' | ' |                  | MODE |   | R   | EGISTE | R |
| D/A | R  | EGISTE | R  | 1  | 0   | 0        | 0 | 0 | 0 | 0                | 0    | 0 | 0   | 0      | 0 |

#### **EORI to CCR**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5  | 4       | 3        | 2  | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|----|---------|----------|----|---|---|
| 0  | 0  | 0  | 0  | 1  | 0  | 1 | 0 | 0 | 0 | 1  | 1       | 1        | 1  | 0 | 0 |
| 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 |   |   | B, | YTE DAT | A (8 BIT | S) | - |   |

#### **EORI to SR**

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8       | 7      | 6  | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|----|---------|--------|----|---|---|---|---|---|---|
| 0  | 0  | 0  | 0  | 1  | 0  | 1  | 0       | 0      | 1  | 1 | 1 | 1 | 1 | 0 | 0 |
|    | •  |    | •  |    |    | 16 | 6-BIT W | ORD DA | ΓA |   |   |   |   |   |   |

#### **EORI**

| 15 | 14 | 13 | 12       | 11     | 10 | 9 | 8        | 7      | 6          | 5                 | 4        | 3      | 2 | 1      | 0 |
|----|----|----|----------|--------|----|---|----------|--------|------------|-------------------|----------|--------|---|--------|---|
| 0  | 0  | _  | _        | 1      | _  | 1 |          | CI.    | ZE         | EFFECTIVE ADDRESS |          |        |   |        |   |
| 0  | U  | "  | "        | '      | "  | ' | "        | ا ا    | <b>Z</b> E |                   | MODE     |        | R | EGISTE | R |
|    |    | 16 | 6-BIT WO | ORD DA | ГА |   |          |        |            | 1                 | 6-BIT BY | TE DAT | A |        |   |
|    |    |    |          |        |    | 3 | 2-BIT LC | NG DAT | Ā          |                   |          |        |   |        |   |

#### **CMPI**

| 15 | 14 | 13 | 12       | 11      | 10 | 9  | 8        | 7      | 6        | 5 | 4        | 3       | 2     | 1       | 0 |
|----|----|----|----------|---------|----|----|----------|--------|----------|---|----------|---------|-------|---------|---|
|    | 0  | 0  |          | 4       | 1  | 0  | 0        | SIZ    | 7E       |   | EFF      | ECTIVE  | ADDRE | ESS     |   |
|    | 0  | "  | "        | '       | '  | "  | 0        | 312    | <u> </u> |   | MODE     |         | R     | REGISTE | R |
|    | •  | 10 | 6-BIT WO | ORD DAT | ΓA | •  |          |        |          | 8 | 8-BIT BY | TE DATA | Ä     |         |   |
|    |    |    |          |         |    | 3. | 2-BIT LC | NG DAT | ·A       |   |          |         |       |         |   |

#### **BTST**

#### BIT NUMBER STATIC, SPECIFIED AS IMMEDIATE DATA

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4      | 3      | 2     | 1      | 0  |
|----|----|----|----|----|----|---|---|---|---|---|--------|--------|-------|--------|----|
| 0  | 0  | 0  | 0  | 1  | 0  | 0 | 0 | 0 | 0 |   | EFF    | ECTIVE | ADDRE | SS     |    |
| U  | "  | "  | "  | '  | "  | " | " | " | " |   | MODE   |        | R     | EGISTE | :R |
| 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 |   |   |   | BIT NU | MBER   |       |        |    |

#### **BCHG**

#### BIT NUMBER STATIC, SPECIFIED AS IMMEDIATE DATA

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4      | 3      | 2     | 1       | 0 |
|----|----|----|----|----|----|---|---|---|---|---|--------|--------|-------|---------|---|
|    |    | 0  | 0  | 1  | 0  | 0 | 0 | 0 | 1 |   | EFF    | ECTIVE | ADDRE | ESS     |   |
| "  | "  | 0  | "  | '  | 0  | " | 0 | " | ' |   | MODE   |        | F     | REGISTE | R |
| 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 |   |   |   | BIT NU | IMBER  | •     |         |   |

#### **BCLR**

#### BIT NUMBER STATIC, SPECIFIED AS IMMEDIATE DATA

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4      | 3      | 2     | 1      | 0 |
|----|----|----|----|----|----|---|---|---|---|---|--------|--------|-------|--------|---|
| 0  | _  | _  |    | 4  | _  | _ | _ | 4 |   |   | EFF    | ECTIVE | ADDRE | SS     |   |
| U  | 0  | "  | "  | '  | 0  | " | " | ' | 0 |   | MODE   |        | R     | EGISTE | R |
| 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 |   |   |   | BIT NU | MBER   |       |        |   |

#### **BSET**

#### BIT NUMBER STATIC, SPECIFIED AS IMMEDIATE DATA

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5  | 4       | 3      | 2     | 1       | 0 |
|----|----|----|----|----|----|---|---|---|---|----|---------|--------|-------|---------|---|
|    | 0  | 0  | 0  | 1  | _  | _ | _ | 1 | 1 |    | EFF     | ECTIVE | ADDRE | ESS     |   |
|    |    | 0  | 0  | '  | "  | " | " | ' | ' |    | MODE    |        | R     | REGISTE | R |
| 0  | 0  | 0  | 0  | 0  | 0  | 0 |   |   |   | ВІ | T NUMBI | ER     |       |         |   |

#### **MOVES**

| 15  | 14 | 13     | 12 | 11 | 10 | 9 | 8 | 7   | 6         | 5 | 4    | 3       | 2     | 1      | 0 |
|-----|----|--------|----|----|----|---|---|-----|-----------|---|------|---------|-------|--------|---|
| 0   | 0  | _      | _  | 1  | 1  | 1 | _ | Q1  | ZE        |   | EF   | FECTIVE | ADDRE | SS     |   |
| U   | "  | "      | "  | '  | '  | ' | " | 31, | <u> L</u> |   | MODE |         | R     | EGISTE | R |
| A/D | R  | EGISTE | R  | dr | 0  | 0 | 0 | 0   | 0         | 0 | 0    | 0       | 0     | 0      | 0 |

#### CAS<sub>2</sub>

| 15   | 14 | 13  | 12 | 11 | 10 | 9  | 8 | 7   | 6 | 5 | 4 | 3 | 2 | 1   | 0 |
|------|----|-----|----|----|----|----|---|-----|---|---|---|---|---|-----|---|
| 0    | 0  | 0   | 0  | 1  | SI | ZE | 0 | 1   | 1 | 1 | 1 | 1 | 1 | 0   | 0 |
| D/A1 |    | Rn1 |    | 0  | 0  | 0  |   | Du1 |   | 0 | 0 | 0 |   | Dc1 |   |
| D/A2 |    | Rn2 |    | 0  | 0  | 0  |   | Du2 |   | 0 | 0 | 0 |   | Dc2 |   |

#### **CAS**

| 15 | 14 | 13 | 12 | 11 | 10  | 9       | 8 | 7  | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|----|----|----|----|-----|---------|---|----|---|---|------|---------|-------|--------|---|
| 0  | 0  | 0  | _  | 1  | CI. | ZE      | 0 | 4  | 1 |   | EF   | FECTIVE | ADDRE | SS     |   |
| U  | U  | U  | U  | '  | 31. | <u></u> | U | '  | ' |   | MODE |         | R     | EGISTE | ₹ |
| 0  | 0  | 0  | 0  | 0  | 0   | 0       |   | Du |   | 0 | 0    | 0       |       | Dc     |   |

#### **BTST**

#### BIT NUMBER DYNAMIC, SPECIFIED IN A REGISTER

| 15 | 14 | 13 | 12 | 11 | 10       | 9 | 8 | 7 | 6 | 5 | 4    | 3      | 2     | 1      | 0 |
|----|----|----|----|----|----------|---|---|---|---|---|------|--------|-------|--------|---|
|    |    | 0  | _  |    | REGISTER | D | 1 | _ | _ |   | EFI  | ECTIVE | ADDRE | SS     |   |
| "  | "  | 0  | "  |    | KEGISTEI | ` | ' | 0 | " |   | MODE |        | R     | EGISTE | R |

#### **BCHG**

| BIT NUMBER | DYNAMIC           | SPECIFIED   | IN A     | REGISTER |
|------------|-------------------|-------------|----------|----------|
|            | D 1 1 1/ (1/11/0) | 01 -011 1-0 | 11 7 / 1 |          |

| 15 | 14 | 13 | 12 | 11 | 10       | 9 | 8 | 7 | 6 | 5 | 4    | 3      | 2     | 1      | 0 |
|----|----|----|----|----|----------|---|---|---|---|---|------|--------|-------|--------|---|
| 0  | _  | 0  | 0  | _  | REGISTER |   | 1 | _ | 1 |   | EFI  | ECTIVE | ADDRE | SS     |   |
| U  | "  | "  | 0  |    | KEGISTER |   | ' | " | ' |   | MODE |        | R     | EGISTE | R |

#### **BCLR**

#### BIT NUMBER DYNAMIC, SPECIFIED IN A REGISTER

| 15 | 14 | 13 | 12 | 11 | 10       | 9 | 8 | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|----|----|----|----|----------|---|---|---|---|---|------|---------|-------|--------|---|
| 0  | 0  | 0  | 0  |    | REGISTER |   | 1 | 1 | _ |   | EFI  | FECTIVE | ADDRE | SS     |   |
| U  | "  | "  | 0  | '  | KEGISTER |   | ' |   | U |   | MODE |         | R     | EGISTE | R |

#### **BSET**

#### BIT NUMBER DYNAMIC, SPECIFIED IN A REGISTER

| 15 | 14 | 13 | 12 | 11 | 10       | 9 | 8 | 7 | 6 | 5 | 4    | 3      | 2     | 1      | 0 |
|----|----|----|----|----|----------|---|---|---|---|---|------|--------|-------|--------|---|
|    | 0  | _  | _  | _  | REGISTER |   | 1 | 4 | 4 |   | EFI  | ECTIVE | ADDRE | SS     |   |
| "  | "  | "  | "  |    | REGISTER |   | ' | ' | ' |   | MODE |        | R     | EGISTE | R |

#### **MOVEP**

| 15 | 14 | 13 | 12 | 11  | 10      | 9   | 8        | 7       | 6   | 5 | 4 | 3 | 2 | 1                 | 0 |
|----|----|----|----|-----|---------|-----|----------|---------|-----|---|---|---|---|-------------------|---|
| 0  | 0  | 0  | 0  | DAT | A REGIS | TER |          | OPMODE  |     | 0 | 0 | 1 |   | ADDRES<br>REGISTE | - |
|    |    |    |    |     |         | 16- | BIT DISF | PLACEME | ENT |   |   |   |   |                   |   |

#### **MOVEA**

| 15 | 14 | 13  | 12       | 11 | 10       | 9  | 8 | 7 | 6 | 5 | 4    | 3   | 2   | 1       | 0 |
|----|----|-----|----------|----|----------|----|---|---|---|---|------|-----|-----|---------|---|
|    | 0  | SIZ | 75       | DE | STINATIO | NC | _ | _ | 1 |   |      | SOU | RCE |         |   |
| "  | "  | 312 | <u>L</u> | R  | EGISTER  | ₹  | " | " | ' |   | MODE |     | R   | EGISTER | ≀ |

#### **MOVE**

| 15 | 14     | 13  | 12       | 11 | 10      | 9     | 8      | 7    | 6 | 5 | 4    | 3   | 2    | 1       | 0 |
|----|--------|-----|----------|----|---------|-------|--------|------|---|---|------|-----|------|---------|---|
| 0  | 0 SIZE |     |          |    |         | DESTI | NOITAN |      |   |   |      | SOU | IRCE |         |   |
|    | 0      | 312 | <u> </u> | R  | REGISTE | R     |        | MODE |   |   | MODE |     | R    | REGISTE | R |

#### **MOVE from SR**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4    | 3   | 2    | 1        | 0 |
|----|----|----|----|----|----|---|---|---|---|---|------|-----|------|----------|---|
| 0  | 1  | _  | _  | _  | _  | _ | 0 | 1 | 1 |   |      | SOU | IRCE |          |   |
| U  | '  | "  | "  | "  | "  | " | " | ' | ' |   | MODE |     | 1    | REGISTER | τ |

| 1 | 5 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4    | 3      | 2     | 1      | 0  |
|---|---|----|----|----|----|----|---|---|---|---|---|------|--------|-------|--------|----|
|   | , | 1  | 0  | _  | 0  | 0  | 1 | 0 | 1 | 4 |   | EFF  | ECTIVE | ADDRE | SS     |    |
| ' | ' | '  | 0  | "  | "  | "  | ' | " | ' | ' |   | MODE |        | R     | EGISTE | :R |

#### **NEGX**

|    | -  |    |    |    |    |   |   |     |          |   |      |         |       |        |   |
|----|----|----|----|----|----|---|---|-----|----------|---|------|---------|-------|--------|---|
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7   | 6        | 5 | 4    | 3       | 2     | 1      | 0 |
| 0  | 1  | 0  | 0  | 0  | 0  | 0 | 0 | 917 | ZE1      |   | EFI  | FECTIVE | ADDRE | SS     |   |
| U  | '  | "  | "  | "  | "  | " | " | 312 | <u> </u> |   | MODE |         | R     | EGISTE | R |

#### **CLR**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7   | 6   | 5 | 4    | 3       | 2     | 1       | 0 |
|----|----|----|----|----|----|---|---|-----|-----|---|------|---------|-------|---------|---|
| 0  | 1  | _  |    | 0  |    | 1 |   | CI. | ZE  |   | EFF  | FECTIVE | ADDRE | ESS     |   |
|    | '  |    | "  |    | "  | ' | " | JI. | Z.L |   | MODE |         | R     | REGISTE | R |

#### **MOVE to CCR**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|----|----|----|----|----|---|---|---|---|---|------|---------|-------|--------|---|
|    | 1  | _  | _  | _  | 1  | _ | _ | 1 | 1 |   | EFF  | FECTIVE | ADDRE | SS     |   |
| U  | '  | U  | U  | U  | '  | U | U | ' | ' |   | MODE |         | R     | EGISTE | R |

#### **NEG**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7   | 6         | 5 | 4    | 3      | 2     | 1      | 0 |
|----|----|----|----|----|----|---|---|-----|-----------|---|------|--------|-------|--------|---|
|    | 1  | 0  | 0  | 0  | 1  | 0 | 0 | Q1  | ZE        |   | EFF  | ECTIVE | ADDRE | SS     |   |
| "  | '  | "  | "  | "  | '  | " | " | 31, | <u> L</u> |   | MODE |        | R     | EGISTE | R |

#### **NOT**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7   | 6         | 5 | 4    | 3      | 2     | 1      | 0 |
|----|----|----|----|----|----|---|---|-----|-----------|---|------|--------|-------|--------|---|
| 0  | 1  | 0  | 0  | 0  | 1  | 1 | 0 | SI. | ZE        |   | EF   | ECTIVE | ADDRE | SS     |   |
| "  | '  | "  | "  | "  | '  | ! | " | 31, | <u> L</u> |   | MODE |        | R     | EGISTE | R |

#### **MOVE to SR**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|----|----|----|----|----|---|---|---|---|---|------|---------|-------|--------|---|
| 0  | 4  | _  | 0  |    | 1  | 1 | 0 | 1 | 4 |   | EF   | FECTIVE | ADDRE | SS     |   |
| U  | '  | "  | 0  | "  | '  | ' | 0 | ' | ' |   | MODE |         | R     | EGISTE | R |

| EXT, | <b>EXT</b>   | B                |
|------|--------------|------------------|
|      | $ ^{\prime}$ | $\boldsymbol{-}$ |

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7      | 6 | 5 | 4 | 3 | 2 | 1      | 0   |
|----|----|----|----|----|----|---|---|--------|---|---|---|---|---|--------|-----|
| 0  | 1  | 0  | 0  | 1  | 0  | 0 |   | OPMODE |   | 0 | 0 | 0 | R | EGISTE | K I |

#### LINK

#### LONG

|   | 15                      | 14                     | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2        | 1 | 0 |  |  |
|---|-------------------------|------------------------|----|----|----|----|---|---|---|---|---|---|---|----------|---|---|--|--|
|   | 0                       | 1                      | 0  | 0  | 1  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 1 | REGISTER |   |   |  |  |
|   | HIGH-ORDER DISPLACEMENT |                        |    |    |    |    |   |   |   |   |   |   |   |          |   |   |  |  |
| ſ |                         | LOW-ORDER DISPLACEMENT |    |    |    |    |   |   |   |   |   |   |   |          |   |   |  |  |

#### **NBCD**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4    | 3      | 2     | 1      | 0 |
|----|----|----|----|----|----|---|---|---|---|---|------|--------|-------|--------|---|
| 0  | 1  | _  | _  | 1  | _  | _ | 0 | _ | _ |   | EFI  | ECTIVE | ADDRE | SS     |   |
| U  | '  | "  | "  | '  | "  | " | " | " | " |   | MODE |        | R     | EGISTE | R |

#### **SWAP**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1      | 0  |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|--------|----|
| 0  | 1  | 0  | 0  | 1  | 0  | 0 | 0 | 0 | 1 | 0 | 0 | 0 | R | EGISTE | 11 |

#### **BKPT**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1      | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|--------|---|
| 0  | 1  | 0  | 0  | 1  | 0  | 0 | 0 | 0 | 1 | 0 | 0 | 1 |   | VECTOR |   |

#### PEA

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4    | 3      | 2     | 1      | 0  |
|----|----|----|----|----|----|---|---|---|---|---|------|--------|-------|--------|----|
| 0  | 1  | 0  | 0  | 1  | _  | _ | _ | _ | 1 |   | EFI  | ECTIVE | ADDRE | SS     |    |
|    | '  | "  | 0  | '  | "  | " | " | " | ' |   | MODE |        | F     | EGISTE | :R |

#### **BGND**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0  | 1  | 0  | 0  | 1  | 0  | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 0 |

#### **ILLEGAL**

|   | - |   | _ |   |   | _ | - | _ |   | _ | - |   | - |   |   | 0 |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| ĺ | 0 | 1 | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 |

#### **TAS**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4    | 3      | 2     | 1      | 0 |
|----|----|----|----|----|----|---|---|---|---|---|------|--------|-------|--------|---|
|    | 1  | 0  | 0  | 1  | 0  | 1 | 0 | 1 | 1 |   | EFI  | ECTIVE | ADDRE | SS     |   |
| "  | '  | "  | "  | '  | "  | ' | " | ' | ' |   | MODE |        | R     | EGISTE | R |

#### **TST**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7   | 6          | 5 | 4    | 3      | 2     | 1      | 0 |
|----|----|----|----|----|----|---|---|-----|------------|---|------|--------|-------|--------|---|
| 0  | 4  | 0  | _  | 1  | 0  | 1 | 0 | CI. | ZE         |   | EFI  | ECTIVE | ADDRE | SS     |   |
| U  | '  | 0  | "  | '  | "  | ' | " | 31. | <b>Z</b> E |   | MODE |        | R     | EGISTE | R |

#### MULU

#### LONG

| 15 | 14 | 13     | 12 | 11 | 10   | 9 | 8 | 7 | 6 | 5                                | 4   | 3       | 2    | 1   | 0  |
|----|----|--------|----|----|------|---|---|---|---|----------------------------------|-----|---------|------|-----|----|
| 0  | 1  | 0      | 0  | 1  | 1    | 0 | 0 | 0 | 0 |                                  | EFI | FECTIVE | ADDR | ESS |    |
| U  | '  | "      | 0  | '  | '    |   | " |   | U | EFFECTIVE ADDRESS  MODE REGISTER |     |         |      |     | R  |
| 0  | RE | GISTER | DI | 0  | SIZE | 0 | 0 | 0 | 0 | 0 0 0 REGISTER Dh                |     |         |      |     | Dh |

#### **MULS**

#### LONG

| 15 | 14 | 13     | 12 | 11 | 10   | 9 | 8 | 7 | 6 | 5                 | 4    | 3 | 2  | 1       | 0  |
|----|----|--------|----|----|------|---|---|---|---|-------------------|------|---|----|---------|----|
| 0  | 1  | 0      | 0  | 1  | 1    | 0 | 0 | 0 | 0 | EFFECTIVE ADDRESS |      |   |    |         |    |
| U  | '  |        |    | '  | '    | U | U | 0 | U |                   | MODE |   | F  | REGISTE | R  |
| 0  | RE | GISTER | DI | 1  | SIZE | 0 | 0 | 0 | 0 | 0                 | 0    | 0 | RE | GISTER  | Dh |

### DIVU, DIVUL

#### LONG

| 15 | 14 | 13     | 12 | 11 | 10   | 9 | 8 | 7 | 6 | 5      | 4  | 3       | 2     | 1       | 0  |
|----|----|--------|----|----|------|---|---|---|---|--------|----|---------|-------|---------|----|
| 0  | 1  | _      | _  | 1  | 1    | 0 | 0 | 0 | _ |        | EF | FECTIVE | ADDRE | SS      |    |
| U  | '  | "      | "  | '  | '    | 0 | 0 | 0 | " | 0 MODE |    |         | F     | REGISTE | R  |
| 0  | RE | GISTER | Dq | 0  | SIZE | 0 | 0 | 0 | 0 | 0      | 0  | 0       | RE    | GISTER  | Dr |

#### **DIVS, DIVSL**

|   |    |             |    |    |    |      |   | LO | NG |   |                   |   |         |    |        |    |  |  |
|---|----|-------------|----|----|----|------|---|----|----|---|-------------------|---|---------|----|--------|----|--|--|
|   | 15 | 14          | 13 | 12 | 11 | 10   | 9 | 8  | 7  | 6 | 5                 | 4 | 3       | 2  | 1      | 0  |  |  |
| Г | 0  | 1           | _  | 0  | 1  | 1    | 0 | _  | _  | 4 | EFFECTIVE ADDRESS |   |         |    |        |    |  |  |
|   | U  | '           | "  | "  | '  | '    | " | "  | "  | ' | MODE R            |   | REGISTE | :R |        |    |  |  |
|   | 0  | REGISTER Da |    |    | 1  | SIZE | 0 | 0  | 0  | 0 | 0                 | 0 | 0       | RE | GISTER | Dr |  |  |

#### **TRAP**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2   | 1   | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|-----|-----|---|
| 0  | 1  | 0  | 0  | 1  | 1  | 1 | 0 | 0 | 1 | 0 | 0 |   | VEC | TOR |   |

#### LINK

|    |    |    |    |    |    |    | WC      | RD     |     |   |   |   |          |   |   |  |  |  |  |
|----|----|----|----|----|----|----|---------|--------|-----|---|---|---|----------|---|---|--|--|--|--|
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8       | 7      | 6   | 5 | 4 | 3 | 2        | 1 | 0 |  |  |  |  |
| 0  | 1  | 0  | 0  | 1  | 1  | 1  | 0       | 0      | 1   | 0 | 1 | 0 | REGISTER |   |   |  |  |  |  |
|    |    |    |    |    |    | WO | RD DISF | PLACEM | ENT |   |   |   |          |   |   |  |  |  |  |

#### UNLK

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1      | 0   |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|--------|-----|
| 0  | 1  | 0  | 0  | 1  | 1  | 1 | 0 | 0 | 1 | 0 | 1 | 1 | R | EGISTE | K I |

#### **MOVE USP**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3  | 2 | 1      | 0 |   |
|----|----|----|----|----|----|---|---|---|---|---|---|----|---|--------|---|---|
| 0  | 1  | 0  | 0  | 1  | 1  | 1 | 0 | 0 | 1 | 1 | 0 | dr | F | EGISTE | R | 1 |

#### **RESET**

|   |   |   |   |   |   |   | - | _ | - | - | - |   | - | _ |   | 0 |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Γ | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 |

#### **NOP**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0  | 1  | 0  | 0  | 1  | 1  | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 1 |

#### **STOP**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8      | 7      | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|--------|--------|---|---|---|---|---|---|---|
| 0  | 1  | 0  | 0  | 1  | 1  | 1 | 0      | 0      | 1 | 1 | 1 | 0 | 0 | 1 | 0 |
|    | -  | -  | -  | -  | -  | ı | MMEDIA | TE DAT | A | - | - | - | - | - |   |

#### **RTE**

|   |   |   |   |   |   | - | - | • | - | - |   | - | _ | - | 0 |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 0 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 1 |

#### **RTD**

| 15 | 14 | 13 | 12 | 11 | 10 | 9    | 8        | 7      | 6   | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|------|----------|--------|-----|---|---|---|---|---|---|
| 0  | 1  | 0  | 0  | 1  | 1  | 1    | 0        | 0      | 1   | 1 | 1 | 0 | 1 | 0 | 0 |
|    |    |    |    |    |    | 16-l | BIT DISF | PLACEM | ENT |   |   |   |   |   |   |

#### RTS

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0  | 1  | 0  | 0  | 1  | 1  | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 0 | 1 |

#### **TRAPV**

| _ | 14 | _ |   |   | _ | - | _ |   | _ | _ |   | _ |   |   | - |  |
|---|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|--|
| 0 | 1  | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 0 |  |

#### **RTR**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0  | 1  | 0  | 0  | 1  | 1  | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 1 |

#### **MOVEC**

| 15  | 14 | 13     | 12 | 11 | 10 | 9 | 8 | 7  | 6     | 5      | 4  | 3 | 2 | 1 | 0  |
|-----|----|--------|----|----|----|---|---|----|-------|--------|----|---|---|---|----|
| 0   | 1  | 0      | 0  | 1  | 1  | 1 | 0 | 0  | 1     | 1      | 1  | 1 | 0 | 1 | dr |
| A/D | R  | EGISTE | R  |    | -  | - | - | CC | NTROL | REGIST | ER |   | - |   |    |

| J. | S | R |
|----|---|---|
|    |   |   |

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4    | 3      | 2     | 1      | 0 |
|----|----|----|----|----|----|---|---|---|---|---|------|--------|-------|--------|---|
| 0  | 1  | 0  | _  | 1  | 1  | 1 | _ | 1 |   |   | EFF  | ECTIVE | ADDRE | SS     |   |
| U  | !  | 0  | "  | '  | '  | ' | " | ' | " |   | MODE |        | R     | EGISTE | R |

#### **JMP**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4    | 3      | 2     | 1      | 0 |
|----|----|----|----|----|----|---|---|---|---|---|------|--------|-------|--------|---|
| 0  | 1  | _  | _  | 1  | 1  | 1 | 0 | 1 | 1 |   | EFI  | ECTIVE | ADDRE | SS     |   |
| U  | '  | "  | "  | '  | '  | ' | " | ' | ' |   | MODE |        | R     | EGISTE | R |

#### **MOVEM**

|   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8           | 7       | 6    | 5 | 4           | 3      | 2     | 1            | 0   |
|---|----|----|----|----|----|----|----|-------------|---------|------|---|-------------|--------|-------|--------------|-----|
|   | 0  | 1  | 0  | 0  | 1  | dr | 0  | 0           | 1       | SIZE |   | EFI<br>MODE | ECTIVE | ADDRE | SS<br>EGISTE | D   |
| ŀ |    |    |    |    |    |    | RE | l<br>GISTER | LIST MA | ASK  |   | WODE        |        |       | LOISTE       | IX. |

#### **LEA**

| 15 | 14 | 13 | 12 | 11 | 10       | 9 | 8 | 7 | 6 | 5 | 4    | 3       | 2       | 1       | 0  |
|----|----|----|----|----|----------|---|---|---|---|---|------|---------|---------|---------|----|
| 0  | 1  | _  |    |    | REGISTER | , | 1 | 1 | 1 |   | EFI  | FECTIVE | E ADDRE | ESS     |    |
| 0  | '  | "  | "  |    | KEGISTER |   | ' | ' | ' |   | MODE |         | F       | REGISTE | :R |

#### **CHK**

| 15 | 14 | 13 | 12 | 11 | 10       | 9 | 8   | 7        | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|----|----|----|----|----------|---|-----|----------|---|---|------|---------|-------|--------|---|
| 0  | 1  | 0  | _  | _  | REGISTER | , | SI  | 70       | _ |   | EF   | FECTIVE | ADDRE | SS     |   |
| U  |    | 0  | "  |    | KEGISTER |   | 31, | <b>4</b> | 0 |   | MODE |         | R     | EGISTE | R |

#### **ADDQ**

| 15 | 14 | 13 | 12 | 11 | 10   | 9 | 8 | 7   | 6        | 5 | 4    | 3      | 2     | 1      | 0 |
|----|----|----|----|----|------|---|---|-----|----------|---|------|--------|-------|--------|---|
| 0  | 1  | 0  | 1  |    | DATA |   | 0 | SI  | 70       |   | EFI  | ECTIVE | ADDRE | SS     |   |
|    | '  | U  |    |    | DATA |   | 0 | 31, | <b>4</b> |   | MODE |        | R     | EGISTE | R |

#### **SUBQ**

| 15 | 14 | 13 | 12 | 11 | 10   | 9 | 8 | 7   | 6          | 5 | 4    | 3       | 2     | 1      | 0 |
|----|----|----|----|----|------|---|---|-----|------------|---|------|---------|-------|--------|---|
| 0  | 1  | _  | 1  |    | DATA |   | 1 | CI. | ZE         |   | EF   | FECTIVE | ADDRE | SS     |   |
| U  | '  | "  | '  |    | DATA |   | ' | 31, | <b>Z</b> E |   | MODE |         | R     | EGISTE | R |

#### **DBcc**

|                     | 15 | 14 | 13 | 12 | 11 | 10   | 9     | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1      | 0 |
|---------------------|----|----|----|----|----|------|-------|---|---|---|---|---|---|---|--------|---|
|                     | 0  | 1  | 0  | 1  |    | COND | ITION |   | 1 | 1 | 0 | 0 | 1 | R | EGISTE | R |
| 16-BIT DISPLACEMENT |    |    |    |    |    |      |       |   |   |   |   |   |   |   |        |   |

#### **TRAPcc**

|   | 15 | 14           | 13 | 12 | 11 | 10   | 9     | 8       | 7      | 6 | 5 | 4 | 3 | 2 | 1     | 0 |
|---|----|--------------|----|----|----|------|-------|---------|--------|---|---|---|---|---|-------|---|
| ſ | 0  | 1            | 0  | 1  |    | COND | ITION |         | 1      | 1 | 1 | 1 | 1 | ( | PMODE |   |
| Ī |    |              |    |    |    |      | C     | OPTIONA | AL WOR | ) |   |   |   |   |       |   |
| ſ |    | OR LONG WORD |    |    |    |      |       |         |        |   |   |   |   |   |       |   |

#### Scc

| 15 | 14 | 13 | 12 | 11        | 10   | 9    | 8 | 7 | 6 | 5   | 4       | 3     | 2  | 1      | 0 |
|----|----|----|----|-----------|------|------|---|---|---|-----|---------|-------|----|--------|---|
| 0  | 1  | 0  | 1  | CONDITION |      |      | 1 | 1 |   | EFI | FECTIVE | ADDRE | SS |        |   |
|    | '  |    | '  |           | COND | THON |   | ' | ' |     | MODE    |       | R  | EGISTE | R |

#### **BRA**

| 15                                               | 14 | 13 | 12 | 11  | 10       | 9      | 8        | 7                  | 6      | 5      | 4    | 3 | 2 | 1 | 0 |  |  |  |
|--------------------------------------------------|----|----|----|-----|----------|--------|----------|--------------------|--------|--------|------|---|---|---|---|--|--|--|
| 0                                                | 1  | 1  | 0  | 0   | 0        | 0      | 0        | 8-BIT DISPLACEMENT |        |        |      |   |   |   |   |  |  |  |
|                                                  | -  | -  | -  | 16- | BIT DISF | PLACEM | ENT IF 8 | B-BIT DIS          | SPLACE | MENT = | \$00 |   |   |   |   |  |  |  |
| 32-BIT DISPLACEMENT IF 8-BIT DISPLACEMENT = \$FF |    |    |    |     |          |        |          |                    |        |        |      |   |   |   |   |  |  |  |

#### **BSR**

| 15 | 14                                               | 13 | 12 | 11 | 10 | 9 | 8 | 7                    | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
|----|--------------------------------------------------|----|----|----|----|---|---|----------------------|---|---|---|---|---|---|---|--|
| 0  | 1                                                | 1  | 0  | 0  | 0  | 0 | 1 | 1 8-BIT DISPLACEMENT |   |   |   |   |   |   |   |  |
|    | 16-BIT DISPLACEMENT IF 8-BIT DISPLACEMENT = \$00 |    |    |    |    |   |   |                      |   |   |   |   |   |   |   |  |
|    | 32-BIT DISPLACEMENT IF 8-BIT DISPLACEMENT = \$FF |    |    |    |    |   |   |                      |   |   |   |   |   |   |   |  |

#### Bcc

| 15 | 14 | 13 | 12 | 11  | 10       | 9     | 8        | 7         | 6     | 5      | 4        | 3     | 2  | 1 | 0 |
|----|----|----|----|-----|----------|-------|----------|-----------|-------|--------|----------|-------|----|---|---|
| 0  | 1  | 1  | 0  |     | COND     | ITION |          |           |       | 8-B    | IT DISPI | ACEME | NT |   |   |
|    |    |    |    | 16- | BIT DISP | LACEM | ENT IF 8 | B-BIT DIS | PLACE | MENT = | \$00     |       |    |   |   |
|    |    |    |    | 32- | BIT DISP | LACEM | ENT IF 8 | B-BIT DIS | PLACE | JENT = | \$FF     |       |    |   |   |

#### **MOVEQ**

| 15 | 14 | 13 | 12 | 11 | 10      | 9 | 8 | 7 | 6 | 5 | 4  | 3 | 2 | 1 | 0 |
|----|----|----|----|----|---------|---|---|---|---|---|----|---|---|---|---|
| 0  | 1  | 1  | 1  | R  | REGISTE | R | 0 |   |   |   | DA |   |   |   |   |

### DIVU, DIVUL

|    |    |    |    |    |         |     | WC | RD |   |   |      |        |       |        |   |
|----|----|----|----|----|---------|-----|----|----|---|---|------|--------|-------|--------|---|
| 15 | 14 | 13 | 12 | 11 | 10      | 9   | 8  | 7  | 6 | 5 | 4    | 3      | 2     | 1      | 0 |
| 1  | 0  | 0  | 0  |    | REGISTE | D   | 0  | 1  | 1 |   | EFF  | ECTIVE | ADDRE | SS     |   |
| '  | "  | "  | "  |    | CLGISTL | IX. | "  | '  | ' |   | MODE |        | R     | EGISTE | R |

#### **SBCD**

| 15 | 14 | 13 | 12 | 11 | 10      | 9 | 8 | 7 | 6 | 5 | 4 | 3   | 2   | 1       | 0     |
|----|----|----|----|----|---------|---|---|---|---|---|---|-----|-----|---------|-------|
| 1  | 0  | 0  | 0  |    | ISTER D |   | 1 | 0 | 0 | 0 | 0 | R/M | REG | ISTER [ | Dx/Ax |

#### **PACK**

| 15 | 14                           | 13 | 12 | 11  | 10      | 9    | 8 | 7 | 6 | 5 | 4 | 3   | 2   | 1       | 0     |
|----|------------------------------|----|----|-----|---------|------|---|---|---|---|---|-----|-----|---------|-------|
| 1  | 0                            | 0  | 0  | REG | ISTER D | у/Ау | 1 | 0 | 1 | 0 | 0 | R/M | REG | ISTER I | Dx/Ax |
|    | 16-BIT EXTENSION: ADJUSTMENT |    |    |     |         |      |   |   |   |   |   |     |     |         |       |

#### **UNPK**

| 15 | 14                           | 13 | 12 | 11  | 10      | 9    | 8 | 7 | 6 | 5 | 4 | 3   | 2   | 1     | 0     |
|----|------------------------------|----|----|-----|---------|------|---|---|---|---|---|-----|-----|-------|-------|
| 1  | 0                            | 0  | 0  | REG | ISTER D | у/Ау | 1 | 1 | 0 | 0 | 0 | R/M | REG | ISTER | Dx/Ax |
|    | 16-BIT EXTENSION: ADJUSTMENT |    |    |     |         |      |   |   |   |   |   |     |     |       |       |

#### **DIVS, DIVSL**

|    |    |    |    |    |         |   | WC | )RD |     |   |                   |   |   |        |   |  |
|----|----|----|----|----|---------|---|----|-----|-----|---|-------------------|---|---|--------|---|--|
| 15 | 14 | 13 | 12 | 11 | 10      | 9 | 8  | 7   | 6   | 5 | 4                 | 3 | 2 | 1      | 0 |  |
| 1  | 0  | 0  | 0  | ь  | REGISTE | D | 1  | 1   | 1   |   | EFFECTIVE ADDRESS |   |   |        |   |  |
| ı  | 0  | 0  | "  |    | KEGISTE | K | '  | '   | ' ' |   | MODE              |   | R | EGISTE | R |  |

#### OR

| 15 | 14 | 13 | 12 | 11  | 10       | 9 | 8        | 7        | 6 | 5 | 4    | 3      | 2     | 1      | 0 |
|----|----|----|----|-----|----------|---|----------|----------|---|---|------|--------|-------|--------|---|
| 1  | 0  | 0  | _  | _   | PEGISTER |   | ,        | OPMODE   | = |   | EFI  | ECTIVE | ADDRE | SS     |   |
| '  | U  | 0  | 0  | , r | KEGISTER | ` | <u> </u> | JFIVIODI | = |   | MODE |        | R     | EGISTE | R |

#### **SUBX**

| 15 | 14 | 13 | 12 | 11  | 10      | 9     | 8 | 7  | 6  | 5 | 4 | 3   | 2   | 1       | 0     |
|----|----|----|----|-----|---------|-------|---|----|----|---|---|-----|-----|---------|-------|
| 1  | 0  | 0  | 1  | REG | ISTER D | )y/Ay | 1 | SI | ZE | 0 | 0 | R/M | REG | ISTER [ | Dx/Ax |

#### SUB

| 15 | 14 | 13 | 12 | 11 | 10         | 9 | 8 | 7       | 6 | 5 | 4    | 3      | 2     | 1      | 0 |
|----|----|----|----|----|------------|---|---|---------|---|---|------|--------|-------|--------|---|
| 1  | 0  | 0  | 1  | -  | REGISTEI   | D |   | OPMODI  | = |   | EFI  | ECTIVE | ADDRE | SS     |   |
| '  | 0  |    | '  | '  | KLGI3 I LI |   | ` | JE MODI | _ |   | MODE |        | R     | EGISTE | R |

#### **SUBA**

| 15 | 14 | 13 | 12 | 11  | 10       | 9  | 8 | 7      | 6 | 5 | 4    | 3      | 2     | 1      | 0 |
|----|----|----|----|-----|----------|----|---|--------|---|---|------|--------|-------|--------|---|
| 1  | 0  | 0  | 1  |     | REGISTE  | D  |   | OPMODE | _ |   | EFI  | ECTIVE | ADDRE | SS     |   |
| 1  | "  | "  | '  | ן ר | KEGISTEI | N. | ' | OFWOOL | = |   | MODE |        | R     | EGISTE | R |

#### **CMPM**

| 15 | 14 | 13 | 12 | 11 | 10     | 9 | 8 | 7     | 6  | 5 | 4 | 3 | 2  | 1      | 0    |
|----|----|----|----|----|--------|---|---|-------|----|---|---|---|----|--------|------|
| 1  | 0  | 1  | 1  |    | GISTER |   | 1 | I 51. | ZE | 0 | 0 | 1 | RE | GISTER | : Ay |

#### **CMP**

| 15 | 14 | 13 | 12 | 11 | 10       | 9 | 8 | 7       | 6        | 5 | 4    | 3       | 2     | 1      | 0 |
|----|----|----|----|----|----------|---|---|---------|----------|---|------|---------|-------|--------|---|
| 1  | 0  | 1  | 1  |    | REGISTER |   |   | OPMODI  | =        |   | EFI  | -ECTIVE | ADDRE | SS     |   |
| '  | "  | '  | '  |    | KLGISTLK |   | ` | JE MODI | <b>L</b> |   | MODE |         | R     | EGISTE | R |

#### **CMPA**

| 15 | 14 | 13 | 12 | 11 | 10       | 9 | 8 | 7      | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|----|----|----|----|----------|---|---|--------|---|---|------|---------|-------|--------|---|
| 1  |    | 1  | 1  |    | REGISTER | ) | , | OPMODE | = |   | EFI  | FECTIVE | ADDRE | SS     |   |
| '  | "  | '  | '  |    | KLGISTLI | ` | ' | JEMODI | _ |   | MODE |         | R     | EGISTE | R |

#### **EOR**

| 15 | 14 | 13 | 12 | 11 | 10       | 9 | 8 | 7        | 6 | 5 | 4    | 3      | 2     | 1      | 0 |
|----|----|----|----|----|----------|---|---|----------|---|---|------|--------|-------|--------|---|
| 4  |    | 4  | 4  |    | REGISTER | , |   | OPMODE   | _ |   | EF   | ECTIVE | ADDRE | SS     |   |
| '  | U  | ı  | ı  |    | REGISTER | ` | ' | JPIVIODE | = |   | MODE |        | R     | EGISTE | R |

| I\/I |   |   |   |
|------|---|---|---|
| IVI  | u | ᄔ | _ |

|      |          |    |    |          |        |    |        | DRD    |   |       |            |         |          |        |    |
|------|----------|----|----|----------|--------|----|--------|--------|---|-------|------------|---------|----------|--------|----|
| 15   | 14       | 13 | 12 | 11       | 10     | 9  | 8      | 7      | 6 | 5     | 4          |         |          |        |    |
| 1    | 1        | 0  | 0  | R        | EGISTE | R  | 0      | 1      | 1 |       |            | FECTIVE |          |        |    |
|      |          |    |    |          |        |    |        |        |   |       | MODE       |         | K        | EGISTE | R  |
| ABC  | D        |    |    |          |        |    |        |        |   |       |            |         |          |        |    |
| 15   | 14       | 13 | 12 | 11       | 10     | 9  | 8      | 7      | 6 | 5     | 4          | 3       | 2        | 1      | 0  |
| 1    | 1        | 0  | 0  | RE       | GISTER | Rx | 1      | 0      | 0 | 0     | 0          | R/M     | RE       | GISTER | Ry |
| MULS | 8        |    |    |          |        |    |        |        |   |       |            |         |          |        |    |
|      |          |    |    |          |        |    | WC     | ORD    |   |       |            |         |          |        |    |
| 15   | 14       | 13 | 12 | 11       | 10     | 9  | . 8    | 7      | 6 |       | 4          |         |          |        | 0  |
| 1    | 1        | 0  | 0  | REGISTER |        |    | 1      | 1      | 1 |       | EF<br>MODE | FECTIVE |          |        | R  |
| EXG  |          |    |    |          |        |    |        |        |   |       |            |         |          |        |    |
| 15   | 14       | 13 | 12 | 11       | 10     | 9  | 8      | 7      | 6 | 5     | 4          | 3       | 2        | 1      | 0  |
| 1    | 1        | 0  | 0  | RE       | GISTER | Rx | 1      |        |   | OPMOD | E          |         | RE       | GISTER | Ry |
| AND  |          |    |    |          |        |    |        |        |   |       |            |         |          |        |    |
| 15   | 14       | 13 | 12 | 11       | 10     | 9  | 8      | 7      | 6 |       | 4          |         |          |        |    |
| 1    | 1        | 0  | 0  | R        | EGISTE | R  |        | OPMODE | • |       | EF         |         |          |        |    |
| ADD  | <b>X</b> |    |    |          |        |    |        |        |   |       | MODE       |         | <u> </u> | EGISTE | К  |
| 15   | 14       | 13 | 12 | 11       | 10     | 9  | 8      | 7      | 6 | 5     | 4          | 3       | 2        | 1      | 0  |
| 1    | 1        | 0  | 1  | RE       | GISTER | Rx | 1      | SIZE   |   | 0     | 0          | R/M     | RE       | GISTER | Ry |
| ADDA | 4        |    |    |          |        |    |        |        |   |       |            |         |          |        |    |
| 15   | 14       | 13 | 12 | 11       | 10     | 9  | 8      | 7      | 6 | 5     | 4          |         | 2        |        | 0  |
| 1    | 1        | 0  | 1  |          |        |    | OPMODE | :      |   | EF    | FECTIVE    | ADDRE   | SS       |        |    |

OPMODE

MODE

REGISTER

REGISTER

#### **ADD**

| 15 | 14 | 13 | 12 | 11 | 10       | 9        | 8 | 7      | 6 | 5 | 4    | 3      | 2     | 1      | 0  |
|----|----|----|----|----|----------|----------|---|--------|---|---|------|--------|-------|--------|----|
| 1  | 1  | 0  | 1  |    | REGISTER | <b>D</b> | , | OPMODE | = |   | EFI  | ECTIVE | ADDRE | SS     |    |
|    | '  | 0  | '  |    | KLGISTLI | `        | ` |        | - |   | MODE |        | R     | EGISTE | :R |

#### ASL, ASR

#### MEMORY SHIFT

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8  | 7 | 6 | 5 | 4    | 3      | 2     | 1       | 0 |
|----|----|----|----|----|----|---|----|---|---|---|------|--------|-------|---------|---|
| 1  | 1  | 1  | 0  | 0  | 0  | 0 | dr | 1 | 1 |   | EFI  | ECTIVE | ADDRE | ESS     |   |
| '  | '  | '  | 0  | 0  | 0  | 0 | dr | ' | ' |   | MODE |        | R     | REGISTE | R |

#### LSL, LSR

#### MEMORY SHIFT

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8  | 7 | 6 | 5 | 4    | 3      | 2     | 1      | 0 |
|----|----|----|----|----|----|---|----|---|---|---|------|--------|-------|--------|---|
| 1  | 1  | 1  | _  | 0  | _  | 1 | dr | 1 | 1 |   | EFI  | ECTIVE | ADDRE | SS     |   |
| '  | '  | '  | U  | U  | U  | ' | dr | ' | ' |   | MODE |        | R     | EGISTE | R |

#### **ROXL, ROXR**

#### MEMORY ROTATE

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8  | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|----|----|----|----|----|---|----|---|---|---|------|---------|-------|--------|---|
| 1  | 1  | 1  |    | _  | 1  |   | dr | 1 | 1 |   | EFF  | FECTIVE | ADDRE | SS     |   |
| ı  | '  | '  | 0  | 0  | '  | 0 | dr | ' | ' |   | MODE |         | R     | EGISTE | R |

## ROL, ROR

#### MEMORY ROTATE

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8  | 7 | 6 | 5                 | 4    | 3 | 2 | 1      | 0 |  |
|----|----|----|----|----|----|---|----|---|---|-------------------|------|---|---|--------|---|--|
| 1  | 1  | 1  | 0  | 0  | 1  | 1 | dr | 1 | 1 | EFFECTIVE ADDRESS |      |   |   |        |   |  |
| '  | '  | '  | 0  | "  | '  | ' | dr | ' | ' |                   | MODE |   | F | EGISTE | R |  |

#### **BFTST**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8      | 7 | 6 | 5        | 4    | 3      | 2     | 1      | 0 |
|----|----|----|----|----|----|---|--------|---|---|----------|------|--------|-------|--------|---|
| 4  | 4  | 4  |    | 4  | _  | _ |        | 4 | 4 |          | EFF  | ECTIVE | ADDRE | SS     |   |
| 1  | '  | '  | "  | '  | 0  | " | "      | ' | ' |          | MODE |        | R     | EGISTE | R |
| 0  | 0  | 0  | 0  | Do |    |   | OFFSET | _ |   | Dw WIDTH |      |        |       |        |   |

#### **BFEXTU**

| 1 | 15 | 14 | 13     | 12 | 11 | 10 | 9 | 8      | 7 | 6        | 5                 | 4    | 3 | 2 | 1       | 0 |
|---|----|----|--------|----|----|----|---|--------|---|----------|-------------------|------|---|---|---------|---|
|   | 1  | 1  | 1      |    | 1  | _  | _ | 1      | 4 | 1        | EFFECTIVE ADDRESS |      |   |   |         |   |
|   | •  | '  | '      | "  | '  | "  | " | '      | ' | '        |                   | MODE |   | F | REGISTE | R |
|   | 0  | R  | EGISTE | R  | Do |    |   | OFFSET |   | Dw WIDTH |                   |      |   |   |         |   |

#### **BFCHG**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8      | 7 | 6 | 5  | 4    | 3      | 2     | 1      | 0 |
|----|----|----|----|----|----|---|--------|---|---|----|------|--------|-------|--------|---|
| 1  | 1  | 1  | 0  | 1  | 0  | 1 | 0      | 1 | 1 |    | EFI  | ECTIVE | ADDRE | SS     |   |
| '  | '  | '  | "  | '  | "  | ' | "      | ' | ' |    | MODE |        | R     | EGISTE | R |
| 0  | 0  | 0  | 0  | Do |    |   | OFFSE1 | Ī |   | Dw |      |        | WIDTH |        |   |

#### **BFEXTS**

| 15 | 14 | 13     | 12 | 11 | 10 | 9 | 8      | 7 | 6 | 5  | 4    | 3      | 2     | 1      | 0 |
|----|----|--------|----|----|----|---|--------|---|---|----|------|--------|-------|--------|---|
| 1  | 1  | 4      | 0  | 4  | 0  | 1 | 1      | 1 | 1 |    | EFI  | ECTIVE | ADDRE | SS     |   |
| '  | '  | '      | "  | '  | 0  | ' | '      | ' | ' |    | MODE |        | R     | EGISTE | R |
| 0  | R  | EGISTE | R  | Do |    |   | OFFSET | _ |   | Dw |      |        | WIDTH |        |   |

#### **BFCLR**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8      | 7 | 6 | 5  | 4    | 3      | 2     | 1      | 0 |
|----|----|----|----|----|----|---|--------|---|---|----|------|--------|-------|--------|---|
| 1  | 1  | 1  | 0  | 4  | 4  | _ |        | 1 | 1 |    | EFF  | ECTIVE | ADDRE | SS     |   |
| 1  | '  | '  | 0  | '  | '  | " | "      | ' | ' |    | MODE |        | R     | EGISTE | R |
| 0  | 0  | 0  | 0  | Do |    | - | OFFSET | _ | - | Dw |      |        | WIDTH |        |   |

#### **BFFFO**

| 15 | 14 | 13     | 12 | 11 | 10 | 9   | 8   | 7 | 6 | 5                   | 4    | 3 | 2 | 1      | 0 |
|----|----|--------|----|----|----|-----|-----|---|---|---------------------|------|---|---|--------|---|
| 1  | 4  | 1      | _  | 1  | 1  | 0   | 1   | 1 | 1 | 1 EFFECTIVE ADDRESS |      |   |   |        |   |
| '  | '  | '      | "  | '  | '  | "   | '   | ' | ' |                     | MODE |   | R | EGISTE | R |
| 0  | R  | EGISTE | R  | Do |    | OFF | SET |   |   | Dw WIDTH            |      |   |   |        |   |

#### **BFSET**

| 15 | 14 | 13 | 12 | 11 | 10              | 9 | 8 | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0  |
|----|----|----|----|----|-----------------|---|---|---|---|---|------|---------|-------|--------|----|
| 1  | 1  | 1  | _  | 1  | 1               | 1 |   | 1 | 1 |   | EFI  | FECTIVE | ADDRE | ESS    |    |
| 1  | '  | '  | "  | '  | '               | ' | 0 | ' | ' |   | MODE |         | R     | EGISTE | :R |
| 0  | 0  | 0  | 0  | Do | OFFSET Dw WIDTH |   |   |   |   |   |      |         |       |        |    |

#### **BFINS**

| 15 | 14 | 13     | 12 | 11 | 10 | 9 | 8      | 7 | 6 | 5                 | 4 | 3 | 2 | 1      | 0 |
|----|----|--------|----|----|----|---|--------|---|---|-------------------|---|---|---|--------|---|
| 1  | 1  | 1      | _  | 4  | 1  | 1 | 1      | 1 | 4 | EFFECTIVE ADDRESS |   |   |   |        |   |
| '  | '  | '      | "  | '  | '  | ' | '      | ' | ' | MODE              |   |   | R | EGISTE | R |
| 0  | R  | EGISTE | R  | Do |    |   | OFFSET | - |   | Dw WIDTH          |   |   |   |        |   |

#### ASL, ASR

#### **REGISTER SHIFT**

| 15 | 14 | 13 | 12 | 11 | 10                 | 9 | 8  | 7  | 6  | 5   | 4 | 3 | 2 | 1       | 0 |
|----|----|----|----|----|--------------------|---|----|----|----|-----|---|---|---|---------|---|
| 1  | 1  | 1  | 0  |    | COUNT/<br>REGISTER | ₹ | dr | SI | ZE | i/r | 0 | 0 | F | REGISTE | R |

#### LSL, LSR

#### **REGISTER SHIFT**

| 15 | 14 | 13 | 12 | 11 | 10                 | 9 | 8  | 7  | 6  | 5   | 4 | 3 | 2 | 1      | 0        |
|----|----|----|----|----|--------------------|---|----|----|----|-----|---|---|---|--------|----------|
| 1  | 1  | 1  | 0  | F  | COUNT/<br>REGISTER |   | dr | SI | ZE | i/r | 0 | 1 | R | EGISTE | <b>\</b> |

#### **ROXL**, **ROXR**

#### REGISTER ROTATE

| 15 | 14 | 13 | 12 | 11 | 10                 | 9 | 8  | 7  | 6  | 5   | 4 | 3 | 2 | 1      | 0        |
|----|----|----|----|----|--------------------|---|----|----|----|-----|---|---|---|--------|----------|
| 1  | 1  | 1  | 0  | F  | COUNT/<br>REGISTER | ₹ | dr | SI | ZE | i/r | 1 | 0 | R | EGISTE | <b>\</b> |

#### ROL, ROR

#### **REGISTER ROTATE**

| 15 | 14 | 13 | 12 | 11 | 10                 | 9 | 8  | 7   | 6  | 5   | 4 | 3 | 2 | 1      | 0 |  |
|----|----|----|----|----|--------------------|---|----|-----|----|-----|---|---|---|--------|---|--|
| 1  | 1  | 1  | 0  | F  | COUNT/<br>REGISTER | ₹ | dr | SIZ | ZE | i/r | 1 | 1 | R | EGISTE | R |  |

#### **PMOVE**

#### MC68EC030, ACX REGISTERS

| 15 | 14 | 13 | 12         | 11 | 10  | 9 | 8 | 7 | 6 | 5 | 4    | 3       | 2       | 1      | 0 |
|----|----|----|------------|----|-----|---|---|---|---|---|------|---------|---------|--------|---|
| 1  | 1  | 1  | 1          | 0  | 0   | 0 | _ | 0 | _ |   | EF   | FECTIVE | E ADDRE | ESS    |   |
| '  | '  | '  | '          | "  | "   | " | " | " | " |   | MODE |         | R       | EGISTE | R |
| 0  | 0  | 0  | P REGISTER |    | R/W | 0 | 0 | 0 | 0 | 0 | 0    | 0       | 0       | 0      |   |

#### **PMOVE**

#### MC68030 ONLY, TT REGISTERS

| 15 | 14 | 13 | 12 | 11         | 10 | 9   | 8  | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|----|----|----|------------|----|-----|----|---|---|---|------|---------|-------|--------|---|
| 4  | 4  | 4  | 4  | _          | _  | _   | 0  | 0 | _ |   | EFI  | FECTIVE | ADDRE | SS     |   |
| '  | '  | '  | '  | "          | "  | "   | 0  | 0 | " |   | MODE |         | R     | EGISTE | R |
| 0  | 0  | 0  | Р  | P REGISTER |    | R/W | FD | 0 | 0 | 0 | 0    | 0       | 0     | 0      | 0 |

#### **PLOAD**

| 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8 | 7 | 6 | 5 | 4    | 3 | 2 | 1      | 0 |
|----|----|----|----|----|----|-----|---|---|---|---|------|---|---|--------|---|
| 1  | 1  | 1  | 1  | _  | 0  |     | 0 | 0 | 0 |   | SS   |   |   |        |   |
| '  | '  | '  | '  | "  | 0  | "   | 0 | 0 | 0 |   | MODE |   | R | EGISTE | R |
| 0  | 0  | 1  | 0  | 0  | 0  | R/W | 0 | 0 | 0 | 0 | FC   |   |   |        |   |

#### **PVALID**

#### VAL CONTAINS ACCESS LEVEL TO TEST AGAINST

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5                 | 4    | 3 | 2 | 1      | 0 |  |
|----|----|----|----|----|----|---|---|---|---|-------------------|------|---|---|--------|---|--|
| 1  | 1  | 1  | 1  | 0  | 0  | _ | _ | 0 | 0 | EFFECTIVE ADDRESS |      |   |   |        |   |  |
| '  | '  | '  | '  | U  | U  |   |   | U | U |                   | MODE |   | R | EGISTE | R |  |
| 0  | 0  | 1  | 0  | 1  | 0  | 0 | 0 | 0 | 0 | 0                 | 0    | 0 | 0 | 0      | 0 |  |

#### **PVALID**

#### MAIN PROCESSOR REGISTER CONTAINS ACCESS LEVEL TO TEST AGAINST

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5                 | 4    | 3 | 2        | 1       | 0 |  |
|----|----|----|----|----|----|---|---|---|---|-------------------|------|---|----------|---------|---|--|
| 1  | 1  | 1  | 1  | 0  | 0  | 0 | 0 | 0 | 0 | EFFECTIVE ADDRESS |      |   |          |         |   |  |
| ı  | '  | '  | '  | "  | "  | " | " | " | 0 |                   | MODE |   | 1        | REGISTE | R |  |
| 0  | 0  | 1  | 0  | 1  | 0  | 0 | 0 | 0 | 0 | 0                 | 0    | 0 | REGISTER |         | R |  |

#### **PFLUSH**

#### MC68030 ONLY

| 15  | 14 | 13 | 12   | 11 | 10 | 9 | 8  | 7  | 6 | 5 | 4    | 3      | 2     | 1      | 0 |
|-----|----|----|------|----|----|---|----|----|---|---|------|--------|-------|--------|---|
| 1 1 | 4  | _  | 4    |    |    |   |    |    | _ |   | EFI  | ECTIVE | ADDRE | SS     |   |
| 1   | '  | '  | '    | "  | "  | " | 0  | 0  | " |   | MODE |        | R     | EGISTE | R |
| 0   | 0  | 1  | MODE |    | 0  | 0 | MA | SK |   |   |      | FC     |       |        |   |

PFLUSHA PFLUSHS

| N/ | IC68851 |  |
|----|---------|--|
| IV | COOOU   |  |

| 15 | 14 | 13 | 12 | 11   | 10 | 9 | 8 | 7  | 6  | 5      | 4   | 3      | 2     | 1       | 0 |
|----|----|----|----|------|----|---|---|----|----|--------|-----|--------|-------|---------|---|
| 1  | 1  | 1  | 1  | 0    | 0  | 0 | 0 | 0  | 0  |        | EFF | ECTIVE | ADDRE | ESS     |   |
| '  | '  | '  | '  | 0    | "  | " | " | "  |    | 0 MODE |     |        | F     | REGISTE | R |
| 0  | 0  | 1  |    | MODE | -  | 0 |   | MA | SK |        |     |        | FC    |         |   |

#### **PMOVE**

#### MC68851, TO/FROM TC, CRP, DRP, SRP, CAL, VAL, SCC, AND AC REGISTERS

| 15 | 14 | 13 | 12 | 11     | 10 | 9   | 8 | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|----|----|----|--------|----|-----|---|---|---|---|------|---------|-------|--------|---|
| 1  | 1  | 1  | 1  | _      | 0  | 0   | 0 | _ | 0 |   | EF   | FECTIVE | ADDRE | SS     |   |
| '  | '  | '  | '  | "      | "  | "   | " | " |   |   | MODE |         | R     | EGISTE | R |
| 0  | 1  | 0  | Р  | REGIST | ER | R/W | 0 | 0 | 0 | 0 | 0    | 0       | 0     | 0      | 0 |

#### **PMOVE**

## MC68030 ONLY, SRP, CRP, AND TC REGISTERS

| 15 | 14 | 13 | 12 | 11     | 10 | 9   | 8  | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|----|----|----|--------|----|-----|----|---|---|---|------|---------|-------|--------|---|
| 1  | 1  | 1  | 1  | 0      | _  | 0   | 0  | _ | _ |   | EF   | FECTIVE | ADDRE | ESS    |   |
| '  | '  | '  | '  | "      | "  | "   | "  | " | " |   | MODE |         | R     | EGISTE | R |
| 0  | 1  | 0  | Р  | REGIST | ER | R/W | FD | 0 | 0 | 0 | 0    | 0       | 0     | 0      | 0 |

#### **PMOVE**

#### MC68030 ONLY, MMUSR

| 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8 | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|----|----|----|----|----|-----|---|---|---|---|------|---------|-------|--------|---|
| 1  | 1  | 1  | 1  | 0  | 0  | 0   | 0 | 0 | 0 |   | EF   | FECTIVE | ADDRE | SS     |   |
|    | '  | '  | '  | "  | "  |     | " |   |   |   | MODE |         | R     | EGISTE | R |
| 0  | 1  | 1  | 0  | 0  | 0  | R/W | 0 | 0 | 0 | 0 | 0    | 0       | 0     | 0      | 0 |

#### **PMOVE**

#### MC68EC030, ACUSR

| 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8 | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|----|----|----|----|----|-----|---|---|---|---|------|---------|-------|--------|---|
| 1  | 1  | 1  | 1  | _  | 0  |     | _ | _ | _ |   | EFI  | FECTIVE | ADDRE | SS     |   |
| '  | '  | '  | '  | "  | "  | "   | " | " | " |   | MODE |         | R     | EGISTE | R |
| 0  | 1  | 1  | 0  | 0  | 0  | R/W | 0 | 0 | 0 | 0 | 0    | 0       | 0     | 0      | 0 |

#### **PMOVE**

#### MC68851, TO/FROM PSR AND PCSR REGISTERS

| 15 | 14 | 13 | 12 | 11     | 10 | 9   | 8 | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|----|----|----|--------|----|-----|---|---|---|---|------|---------|-------|--------|---|
| 1  | 4  |    | 4  | _      |    |     | _ | _ |   |   | EF   | FECTIVE | ADDRE | SS     |   |
| '  | '  | '  | '  | "      | "  | "   | 0 | 0 | " |   | MODE |         | R     | EGISTE | R |
| 0  | 1  | 1  | Р  | REGIST | ER | R/W | 0 | 0 | 0 | 0 | 0    | 0       | 0     | 0      | 0 |

#### **PMOVE**

#### MC68851, TO/FROM BADX AND BACX REGISTERS

| 15 | 14 | 13 | 12 | 11     | 10 | 9   | 8 | 7 | 6 | 5 | 4     | 3       | 2    | 1      | 0 |
|----|----|----|----|--------|----|-----|---|---|---|---|-------|---------|------|--------|---|
| 1  | 1  | 1  | 1  | _      | _  | _   | _ | _ | _ |   | EFFE( | CTIVE A | DDRE | SS     |   |
| '  | '  | '  | '  | "      | "  | "   | " | " | " |   | MODE  |         | R    | EGISTE | R |
| 0  | 1  | 1  | Р  | REGIST | ER | R/W | 0 | 0 | 0 | 0 | N     | NUM     |      | 0      | 0 |

#### **PTEST**

#### MC68EC030

|   | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8 | 7 | 6      | 5 | 4           | 3      | 2     | 1              | 0  |
|---|----|----|----|----|----|----|-----|---|---|--------|---|-------------|--------|-------|----------------|----|
|   | 1  | 1  | 1  | 1  | 0  | 0  | 0   | 0 | 0 | 0      |   | EFI<br>MODE | ECTIVE | ADDRE | ESS<br>REGISTE | :R |
| F | 1  | 0  | 0  | 0  | 0  | 0  | R/W | 0 | R | EGISTE | R |             |        | FC    |                |    |

## **PTEST**

## MC68030 ONLY

| 15 | 14 | 13 | 12 | 11    | 10 | 9   | 8 | 7    | 6    | 5 | 4    | 3      | 2     | 1      | 0  |
|----|----|----|----|-------|----|-----|---|------|------|---|------|--------|-------|--------|----|
| 1  | 1  | 1  | 1  | 0     | 0  | 0   | 0 | 0    | 0    |   | EFF  | ECTIVE | ADDRE | SS     |    |
| '  | '  | '  | '  | "     | 0  | "   | 0 | "    | "    |   | MODE |        | F     | EGISTE | :R |
| 1  | 0  | 0  |    | LEVEL |    | R/W | Α | REGI | STER |   |      | F      | С     |        |    |

## **PTEST**

#### MC68851

| 15 | 14 | 13 | 12 | 11    | 10 | 9   | 8 | 7      | 6  | 5 | 4    | 3      | 2     | 1      | 0 |
|----|----|----|----|-------|----|-----|---|--------|----|---|------|--------|-------|--------|---|
| 1  | 1  | 1  | 1  | _     | _  | _   | 0 | _      | _  |   | EFF  | ECTIVE | ADDRE | SS     |   |
| 1  | '  | '  | '  | "     | "  | "   | " | "      | "  |   | MODE |        | R     | EGISTE | R |
| 1  | 0  | 0  |    | LEVEL |    | R/W | Α | REGIST | ER |   |      | F      | С     |        |   |

## **PFLUSHR**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|----|----|----|----|----|---|---|---|---|---|------|---------|-------|--------|---|
| 1  | 1  | 1  | 1  | _  | _  | _ | 0 | 0 | _ |   | EF   | FECTIVE | ADDRE | SS     |   |
| '  | '  | '  | '  | "  | "  | " | " | " | " |   | MODE |         | R     | EGISTE | R |
| 1  | 0  | 1  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0    | 0       | 0     | 0      | 0 |

## **PScc**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5             | 4   | 3      | 2       | 1   | 0 |
|----|----|----|----|----|----|---|---|---|---|---------------|-----|--------|---------|-----|---|
| 1  | 1  | 1  | 1  | 0  | 0  | 0 | 0 | 0 | 1 |               | EFF | ECTIVE | ADDRE   | ESS |   |
| ı  | !  | '  | '  | "  | "  | 0 | " | " | ' | MODE REGISTER |     |        |         | R   |   |
| 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 |               | MC  | 68851  | CONDITI | ON  |   |

## **PDBcc**

| 15 | 14                                    | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2   | 1      | 0     |
|----|---------------------------------------|----|----|----|----|---|---|---|---|---|---|---|-----|--------|-------|
| 1  | 1                                     | 1  | 1  | 0  | 0  | 0 | 0 | 0 | 1 | 0 | 0 | 1 | COU | NT REG | ISTER |
| 0  | 0 0 0 0 0 0 0 0 0 0 MC68851 CONDITION |    |    |    |    |   |   |   |   |   |   |   |     |        |       |
|    | 16-BIT DISPLACEMENT                   |    |    |    |    |   |   |   |   |   |   |   |     |        |       |

## **PTRAPcc**

| 15 | 14                                                                    | 13 | 12 | 11    | 10      | 9      | 8      | 7      | 6      | 5        | 4      | 3                 | 2 | 1      | 0 |  |  |  |  |  |
|----|-----------------------------------------------------------------------|----|----|-------|---------|--------|--------|--------|--------|----------|--------|-------------------|---|--------|---|--|--|--|--|--|
| 1  | 1                                                                     | 1  | 1  | 0     | 0       | 0      | 0      | 0      | 1      | 1        | 1      | 1                 | ( | OPMODE |   |  |  |  |  |  |
| 0  | 0                                                                     | 0  | 0  | 0     | 0       | 0      | 0      | 0      | 0      |          | MC     | MC68851 CONDITION |   |        |   |  |  |  |  |  |
|    | 16-BIT OPERAND OR MOST SIGNIFICANT WORD OF 32-BIT OPERAND (IF NEEDED) |    |    |       |         |        |        |        |        |          |        |                   |   |        |   |  |  |  |  |  |
|    |                                                                       |    |    | LEAST | SIGNIFI | CANT W | ORD OF | 32-BIT | OPERAN | ND (IF N | EEDED) |                   |   |        |   |  |  |  |  |  |

## **PBcc**

| 1 | 5                                                                   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---|---------------------------------------------------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1 | 1 1 1 0 0 0 1 SIZE MC68851 CONDITION                                |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|   | 16-BIT DISPLACEMENT OR MOST SIGNIFICANT WORD OF 32-BIT DISPLACEMENT |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|   | LEAST SIGNIFICANT WORD OF 32-BIT DISPLACEMENT (IF NEEDED)           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

## **PSAVE**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5                 | 4    | 3 | 2 | 1      | 0 |
|----|----|----|----|----|----|---|---|---|---|-------------------|------|---|---|--------|---|
| 1  | 1  | 1  | 1  | 0  | 0  | 0 | 1 | 0 | 0 | EFFECTIVE ADDRESS |      |   |   |        |   |
| '  | '  | '  | '  | "  | 0  | " | ' | " | " |                   | MODE |   | R | EGISTE | R |

#### **PRESTORE**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|----|----|----|----|----|---|---|---|---|---|------|---------|-------|--------|---|
| 1  | 1  | 1  | 1  | 0  | _  | _ | 1 | _ | 1 |   | EFI  | FECTIVE | ADDRE | SS     |   |
| '  | '  | '  | '  |    | "  | 0 | ' | " | ' |   | MODE |         | R     | EGISTE | R |

#### **PFLUSH**

#### MC68EC040, POSTINCREMENT SOURCE AND DESTINATION

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4   | 3    | 2   | 1      | 0   |
|----|----|----|----|----|----|---|---|---|---|---|-----|------|-----|--------|-----|
| 1  | 1  | 1  | 1  | 0  | 1  | 0 | 1 | 0 | 0 | 0 | OPM | IODE | I 1 | EGISTE | r 1 |

## **PFLUSH**

## MC68040/MC68LC040

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4   | 3   | 2        | 1 | 0  |
|----|----|----|----|----|----|---|---|---|---|---|-----|-----|----------|---|----|
| 1  | 1  | 1  | 1  | 0  | 1  | 0 | 1 | 0 | 0 | 0 | OPM | ODE | REGISTER |   | 11 |

## **PTEST**

#### MC68040/MC68LC040

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5   | 4 | 3 | 2 | 1      | 0 |  |
|----|----|----|----|----|----|---|---|---|---|-----|---|---|---|--------|---|--|
| 1  | 1  | 1  | 1  | 0  | 1  | 0 | 1 | 0 | 1 | R/W | 0 | 1 | R | EGISTE | R |  |

## **PTEST**

#### MC68EC040

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5   | 4 | 3 | 2 | 1      | 0 |
|----|----|----|----|----|----|---|---|---|---|-----|---|---|---|--------|---|
| 1  | 1  | 1  | 1  | 0  | 1  | 0 | 1 | 0 | 1 | R/W | 0 | 1 | R | EGISTE | 1 |

#### **CINV**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7   | 6   | 5 | 4   | 3   | 2 | 1      | 0 |
|----|----|----|----|----|----|---|---|-----|-----|---|-----|-----|---|--------|---|
| 1  | 1  | 1  | 1  | 0  | 1  | 0 | 0 | CAC | CHE | 0 | SCO | OPE | R | EGISTE | 1 |

## **CPUSH**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7   | 6  | 5 | 4     | 3  | 2 | 1      | 0   |
|----|----|----|----|----|----|---|---|-----|----|---|-------|----|---|--------|-----|
| 1  | 1  | 1  | 1  | 0  | 1  | 0 | 0 | CAC | HE | 1 | l sca | PE | R | EGISTE | 2 1 |

#### MOVE16

#### ABSOLUTE LONG ADDRESS SOURCE OR DESTINATION

| 15 | 14                 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4    | 3   | 2  | 1      | 0    |
|----|--------------------|----|----|----|----|---|---|---|---|---|------|-----|----|--------|------|
| 1  | 1                  | 1  | 1  | 0  | 1  | 1 | 0 | 0 | 0 | 0 | OPMO | DDE | RE | GISTER | : Ay |
|    | HIGH-ORDER ADDRESS |    |    |    |    |   |   |   |   |   |      |     |    |        |      |
|    | LOW-ORDER ADDRESS  |    |    |    |    |   |   |   |   |   |      |     |    |        |      |

#### MOVE16

#### POSTINCREMENT SOURCE AND DESTINATION

| 15 | • | 14 | 13     | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2  | 1      | 0  |
|----|---|----|--------|----|----|----|---|---|---|---|---|---|---|----|--------|----|
| 1  |   | 1  | 1      | 1  | 0  | 1  | 1 | 0 | 0 | 0 | 1 | 0 | 0 | RE | GISTER | Ax |
| 1  |   | RE | GISTER | Ay | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0  | 0      | 0  |

## TBLU, TBLUN

#### TABLE LOOKUP AND INTERPOLATE

| 15 | 14 | 13     | 12 | 11 | 10 | 9 | 8 | 7    | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|----|--------|----|----|----|---|---|------|---|---|------|---------|-------|--------|---|
| 1  | 1  | 1      | 1  | 1  | 0  | 0 | 0 | 0    | 0 |   | EF   | FECTIVE | ADDRE | SS     |   |
| '  | '  | '      | '  | '  | U  |   |   |      |   |   | MODE |         | R     | EGISTE | R |
| 0  | RE | GISTER | Dx | 0  | R  | 0 | 1 | SIZE | 0 | 0 | 0    | 0       | 0     | 0      | 0 |

## TBLS, TBLSN

#### TABLE LOOKUP AND INTERPOLATE

| 15 | 14 | 13     | 12 | 11 | 10 | 9 | 8 | 7  | 6  | 5 | 4    | 3       | 2     | 1      | 0 |
|----|----|--------|----|----|----|---|---|----|----|---|------|---------|-------|--------|---|
| 1  | 1  | 1      | 1  | 1  | 0  | 0 | 0 | 0  | 0  |   | EFI  | FECTIVE | ADDRE | SS     |   |
| '  | '  | '      | '  | '  |    | " | " | "  | "  |   | MODE |         | R     | EGISTE | R |
| 0  | RE | GISTER | Dx | 1  | R  | 0 | 1 | SI | ZE | 0 | 0    | 0       | 0     | 0      | 0 |

## TBLU, TBLUN

#### DATA REGISTER INTERPOLATE

| 15 | 14 | 13     | 12 | 11 | 10 | 9 | 8 | 7  | 6  | 5 | 4 | 3 | 2   | 1      | 0   |
|----|----|--------|----|----|----|---|---|----|----|---|---|---|-----|--------|-----|
| 1  | 1  | 1      | 1  | 1  | 0  | 0 | 0 | 0  | 0  | 0 | 0 | 0 | REC | SISTER | Dym |
| 0  | RE | GISTER | Dx | 0  | R  | 0 | 0 | SI | ZE | 0 | 0 | 0 | REC | SISTER | Dyn |

# TBLS, TBLSN

## DATA REGISTER INTERPOLATE

| 15 | 14 | 13     | 12 | 11 | 10 | 9 | 8 | 7 | 6  | 5 | 4 | 3 | 2   | 1      | 0   |
|----|----|--------|----|----|----|---|---|---|----|---|---|---|-----|--------|-----|
| 1  | 1  | 1      | 1  | 1  | 0  | 0 | 0 | 0 | 0  | 0 | 0 | 0 | REC | SISTER | Dym |
| 0  | RE | GISTER | Dx | 1  | R  | 0 | 0 |   | ZE | 0 | 0 | 0 | REC | SISTER | Dyn |

## **LPSTOP**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8      | 7      | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|--------|--------|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 1  | 1  | 0  | 0 | 0      | 0      | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 0  | 0  | 0  | 0  | 0  | 0  | 0 | 1      | 1      | 1 | 0 | 0 | 0 | 0 | 0 | 0 |
|    | -  | -  | -  | -  | -  | ı | MMEDIA | TE DAT | A | - | - | - | - | - |   |

## **FMOVECR**

| 15 | 14 | 13 | 12 | 11  | 10          | 9   | 8                  | 7 | 6 | 5 | 4 | 3             | 2 | 1 | 0 |
|----|----|----|----|-----|-------------|-----|--------------------|---|---|---|---|---------------|---|---|---|
| 1  | 1  | 1  | 1  | COF | ROCES<br>ID | SOR | 0                  | 0 | 0 | 0 | 0 | 0             | 0 | 0 | 0 |
| 0  | 1  | 0  | 1  | 1   | 1           | 1   | STINATI<br>REGISTE |   |   |   |   | ROM<br>OFFSET | - |   |   |

## **FINT**

| 15 | 14  | 13 | 12 | 11                | 10    | 9   | 8       | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|-----|----|----|-------------------|-------|-----|---------|---|---|---|------|---------|-------|--------|---|
| 1  | 1   | 1  | 1  | COP               | ROCES | SOR |         | _ | _ |   | EF   | FECTIVE | ADDRE | SS     |   |
| '  | '   | '  | '  |                   | ID    |     | "       | " | " |   | MODE |         | R     | EGISTE | R |
| 0  | R/M | 0  |    | SOURCE<br>PECIFIE |       |     | STINATI |   | 0 | 0 | 0    | 0       | 0     | 0      | 1 |

## **FSINH**

|   | 15 | 14  | 13 | 12 | 11                | 10    | 9   | 8 | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|---|----|-----|----|----|-------------------|-------|-----|---|---|---|---|------|---------|-------|--------|---|
| Г | 1  | 1   | 1  | 1  | COP               | ROCES | SOR | _ | _ | _ |   | EF   | FECTIVE | ADDRE | ESS    |   |
|   | '  | '   | '  | '  |                   | ID    |     |   | " | " |   | MODE |         | R     | EGISTE | R |
|   | 0  | R/M | 0  |    | SOURCE<br>PECIFIE |       | DES |   |   | 0 | 0 | 0    | 0       | 0     | 1      | 0 |

## **FINTRZ**

| 15 | 14  | 13 | 12 | 11                | 10    | 9   | 8                 | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|-----|----|----|-------------------|-------|-----|-------------------|---|---|---|------|---------|-------|--------|---|
| 1  | 1   | 1  | 1  | COP               | ROCES | SOR | _                 | _ | _ |   | EFI  | FECTIVE | ADDRE | SS     |   |
| '  | '   | '  | '  |                   | ID    |     | "                 | " | " |   | MODE |         | R     | EGISTE | R |
| 0  | R/M | 0  |    | SOURCE<br>PECIFIE |       |     | STINATI<br>EGISTE |   | 0 | 0 | 0    | 0       | 0     | 1      | 1 |

## FLOGNP1

| 15 | 14  | 13 | 12 | 11                | 10     | 9   | 8                 | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|-----|----|----|-------------------|--------|-----|-------------------|---|---|---|------|---------|-------|--------|---|
| 1  | 1   | 1  | 1  | COF               | PROCES | SOR | _                 | 0 | 0 |   | EFI  | FECTIVE | ADDRE | SS     |   |
| '  | !   | '  | '  |                   | ID     |     | "                 | 0 | U |   | MODE |         | R     | EGISTE | R |
| 0  | R/M | 0  |    | SOURCE<br>PECIFIE |        |     | STINATI<br>EGISTE |   | 0 | 0 | 0    | 0       | 1     | 1      | 0 |

## FETOXM1

| 15 | 14  | 13 | 12 | 11                | 10     | 9   | 8                 | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|-----|----|----|-------------------|--------|-----|-------------------|---|---|---|------|---------|-------|--------|---|
| 1  | 1   | 1  | 1  | COF               | PROCES | SOR | _                 | 0 | 0 |   | EFI  | FECTIVE | ADDRE | ESS    |   |
| '  | '   | '  | '  |                   | ID     |     | 0                 |   | U |   | MODE |         | R     | EGISTE | R |
| 0  | R/M | 0  |    | SOURCE<br>PECIFIE |        |     | STINATI<br>EGISTE |   | 0 | 0 | 0    | 1       | 0     | 0      | 0 |

## **FTANH**

|   | 15 | 14  | 13 | 12 | 11                | 10    | 9   | 8                 | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|---|----|-----|----|----|-------------------|-------|-----|-------------------|---|---|---|------|---------|-------|--------|---|
| Γ | 1  | 1   | 1  | 1  | COF               | ROCES | SOR | _                 | _ | 0 |   | EF   | FECTIVE | ADDRE | SS     |   |
|   | '  | '   | '  | '  |                   | ID    |     |                   | " | 0 |   | MODE |         | R     | EGISTE | R |
|   | 0  | R/M | 0  |    | SOURCE<br>PECIFIE |       |     | STINATI<br>EGISTE |   | 0 | 0 | 0    | 1       | 0     | 0      | 1 |

## **FATAN**

| 15 | 14  | 13 | 12 | 11     | 10          | 9 | 8                 | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|-----|----|----|--------|-------------|---|-------------------|---|---|---|------|---------|-------|--------|---|
| 1  | 1   | 1  | 1  | COF    | COPROCESSOR |   |                   | 0 |   |   | EF   | FECTIVE | ADDRE | SS     |   |
| '  | '   | '  | '  |        | ID          |   |                   | " | " |   | MODE |         | R     | EGISTE | R |
| 0  | R/M | 0  |    | SOURCE |             |   | STINATI<br>EGISTE |   | 0 | 0 | 0    | 1       | 0     | 1      | 0 |

## **FASIN**

| 15 | 14  | 13 | 12 | 11     | 10    | 9   | 8       | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|-----|----|----|--------|-------|-----|---------|---|---|---|------|---------|-------|--------|---|
| 4  | 4   | 4  |    | COF    | ROCES | SOR |         | _ | 0 |   | EF   | FECTIVE | ADDRE | SS     |   |
| '  | '   | '  | '  |        | ID    |     | "       | " | 0 |   | MODE |         | R     | EGISTE | R |
| 0  | R/M | 0  |    | SOURCE |       |     | STINATI |   | 0 | 0 | 0    | 1       | 1     | 0      | 0 |

## **FATANH**

| 15 | 14  | 13 | 12 | 11     | 10     | 9 | 8                 | 7 | 6 | 5   | 4       | 3     | 2  | 1      | 0 |
|----|-----|----|----|--------|--------|---|-------------------|---|---|-----|---------|-------|----|--------|---|
| 1  | 1   | 1  | 1  | COF    | PROCES | _ | _                 | _ |   | EFI | FECTIVE | ADDRE | SS |        |   |
| ,  | '   | '  | '  |        | ID     |   | "                 | " | " |     | MODE    |       | R  | EGISTE | R |
| 0  | R/M | 0  |    | SOURCE |        |   | STINATI<br>EGISTE |   | 0 | 0   | 0       | 1     | 1  | 0      | 1 |

## **FSIN**

| 15 | 14  | 13 | 12 | 11     | 10          | 9   | 8       | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|-----|----|----|--------|-------------|-----|---------|---|---|---|------|---------|-------|--------|---|
| 1  | 1   | 1  | 1  | COP    | ROCES       | SOR | 0       | _ | 0 |   | EF   | FECTIVE | ADDRE | ESS    |   |
|    | '   | '  | '  |        | COPROCESSOR |     |         | " | 0 |   | MODE |         | R     | EGISTE | R |
| 0  | R/M | 0  |    | SOURCE |             |     | STINATI |   | 0 | 0 | 0    | 1       | 1     | 1      | 0 |

## **FTAN**

| 15 | 14  | 13 | 12 | 11                | 10    | 9   | 8                  | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|-----|----|----|-------------------|-------|-----|--------------------|---|---|---|------|---------|-------|--------|---|
| 1  | 1   | 1  | 1  | COF               | ROCES | SOR | 0                  | 0 | 0 |   | EF   | FECTIVE | ADDRE | ESS    |   |
| •  | '   | '  | '  |                   | ID    |     | "                  |   |   |   | MODE |         | R     | EGISTE | R |
| 0  | R/M | 0  |    | SOURCE<br>PECIFIE |       |     | STINATI<br>REGISTE |   | 0 | 0 | 0    | 1       | 1     | 1      | 1 |

## **FETOX**

| 15 | 14  | 13 | 12 | 11                | 10          | 9 | 8                 | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|-----|----|----|-------------------|-------------|---|-------------------|---|---|---|------|---------|-------|--------|---|
| 1  | 4   | 1  | 1  | COF               | COPROCESSOR |   |                   | 0 | _ |   | EF   | FECTIVE | ADDRE | SS     |   |
| '  | '   | '  | '  |                   | ID          |   |                   | " | " |   | MODE |         | R     | EGISTE | R |
| 0  | R/M | 0  |    | SOURCE<br>PECIFIE |             |   | STINATI<br>EGISTE |   | 0 | 0 | 1    | 0       | 0     | 0      | 0 |

## **FTWOTOX**

| 15 | 14  | 13 | 12 | 11                | 10     | 9   | 8       | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|-----|----|----|-------------------|--------|-----|---------|---|---|---|------|---------|-------|--------|---|
| 1  | 1   | 1  | 1  | COF               | PROCES | SOR |         | 0 |   |   | EF   | FECTIVE | ADDRE | SS     |   |
| '  | '   | '  | '  |                   | ID     |     |         | " | " |   | MODE |         | R     | EGISTE | R |
| 0  | R/M | 0  |    | SOURCE<br>PECIFIE |        |     | STINATI |   | 0 | 0 | 1    | 0       | 0     | 0      | 1 |

## **FTENTOX**

| 15 | 14  | 13 | 12 | 11                | 10     | 9   | 8                 | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|-----|----|----|-------------------|--------|-----|-------------------|---|---|---|------|---------|-------|--------|---|
| 1  | 1   | 1  | 1  | COF               | PROCES | SOR | _                 | 0 |   |   | EF   | FECTIVE | ADDRE | SS     |   |
| '  | '   | '  | '  |                   | ID     |     | "                 | 0 | " |   | MODE |         | F     | EGISTE | R |
| 0  | R/M | 0  |    | SOURCE<br>PECIFIE |        |     | STINATI<br>EGISTE | - | 0 | 0 | 1    | 0       | 0     | 1      | 0 |

## **FLOGN**

|   | 15 | 14  | 13 | 12 | 11                | 10    | 9   | 8                 | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|---|----|-----|----|----|-------------------|-------|-----|-------------------|---|---|---|------|---------|-------|--------|---|
| ſ | 1  | 1   | 1  | 1  | COF               | ROCES | SOR | 0                 | 0 | _ |   | EF   | FECTIVE | ADDRE | ESS    |   |
|   | '  | '   | !  | '  |                   | ID    |     | "                 | 0 | " |   | MODE |         | R     | EGISTE | R |
|   | 0  | R/M | 0  |    | SOURCE<br>PECIFIE |       |     | STINATI<br>EGISTE |   | 0 | 0 | 1    | 0       | 1     | 0      | 0 |

## FLOG10

| 15 | 14  | 13 | 12 | 11                | 10     | 9   | 8                 | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|-----|----|----|-------------------|--------|-----|-------------------|---|---|---|------|---------|-------|--------|---|
| 1  | 1   | 1  | 1  | COF               | PROCES | SOR | _                 | 0 | 0 |   | EFI  | FECTIVE | ADDRE | ESS    |   |
| '  | '   | '  | '  |                   | ID     |     |                   |   | 0 |   | MODE |         | R     | EGISTE | R |
| 0  | R/M | 0  |    | SOURCE<br>PECIFIE |        |     | STINATI<br>EGISTE |   | 0 | 0 | 1    | 0       | 1     | 0      | 1 |

## FLOG2

|   | 15 | 14  | 13 | 12 | 11     | 10    | 9   | 8                 | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|---|----|-----|----|----|--------|-------|-----|-------------------|---|---|---|------|---------|-------|--------|---|
| Γ | 1  | 1   | 1  | 1  | COF    | ROCES | SOR | 0                 | _ | 0 |   | EF   | FECTIVE | ADDRE | SS     |   |
|   | ı  | '   | '  | '  |        | ID    |     | 0                 | " | 0 |   | MODE |         | R     | EGISTE | R |
|   | 0  | R/M | 0  |    | SOURCE |       |     | STINATI<br>EGISTE |   | 0 | 0 | 1    | 0       | 1     | 1      | 0 |

## **FCOSH**

|   | 15 | 14  | 13 | 12 | 11                | 10                | 9   | 8                 | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|---|----|-----|----|----|-------------------|-------------------|-----|-------------------|---|---|---|------|---------|-------|--------|---|
| Γ | 1  | 1   | 1  | 1  | COF               | ROCES             | SOR | 0                 | _ | 0 |   | EF   | FECTIVE | ADDRE | SS     |   |
|   | '  | '   | '  | '  |                   | COPROCESSOR<br>ID |     |                   | " | 0 |   | MODE |         | R     | EGISTE | R |
|   | 0  | R/M | 0  |    | SOURCE<br>PECIFIE |                   |     | STINATI<br>EGISTE |   | 0 | 0 | 1    | 1       | 0     | 0      | 1 |

## **FACOS**

| 15 | 14  | 13 | 12 | 11     | 10          | 9 | 8                 | 7 | 6 | 5 | 4    | 3       | 2       | 1      | 0 |
|----|-----|----|----|--------|-------------|---|-------------------|---|---|---|------|---------|---------|--------|---|
| 1  | 1   | 1  | 1  | COF    | COPROCESSOR |   |                   | _ | _ |   | EF   | FECTIVE | E ADDRE | SS     |   |
| ı  | '   | '  | '  |        | ID          |   |                   | " | " |   | MODE |         | R       | EGISTE | R |
| 0  | R/M | 0  |    | SOURCE |             |   | STINATI<br>EGISTE |   | 0 | 0 | 1    | 1       | 1       | 0      | 0 |

## **FCOS**

| 15 | 14  | 13 | 12 | 11                | 10     | 9   | 8                  | 7 | 6 | 5 | 4    | 3       | 2       | 1      | 0 |
|----|-----|----|----|-------------------|--------|-----|--------------------|---|---|---|------|---------|---------|--------|---|
| 4  | 4   | 4  | 1  | COF               | PROCES | SOR |                    |   |   |   | EF   | FECTIVE | E ADDRE | SS     |   |
| 1  | '   | '  | '  |                   | ID     |     |                    | 0 | " |   | MODE |         | R       | EGISTE | R |
| 0  | R/M | 0  |    | SOURCE<br>PECIFIE |        |     | STINATI<br>REGISTE |   | 0 | 0 | 1    | 1       | 1       | 0      | 1 |

## **FGETEXP**

| 15 | 14  | 13 | 12 | 11                | 10    | 9   | 8                  | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|-----|----|----|-------------------|-------|-----|--------------------|---|---|---|------|---------|-------|--------|---|
| 1  | 4   | 4  | 4  | COP               | ROCES | SOR |                    |   | _ |   | EF   | FECTIVE | ADDRE | SS     |   |
| 1  | '   | '  | '  |                   | ID    |     | 0                  | " | " |   | MODE |         | R     | EGISTE | R |
| 0  | R/M | 0  |    | SOURCE<br>PECIFIE |       |     | STINATI<br>REGISTE |   | 0 | 0 | 1    | 1       | 1     | 1      | 0 |

## **FGETMAN**

| 15 | 14  | 13 | 12 | 11     | 10    | 9   | 8       | 7 | 6 | 5 | 4    | 3       | 2     | 1       | 0 |
|----|-----|----|----|--------|-------|-----|---------|---|---|---|------|---------|-------|---------|---|
| 1  | 4   | 1  | 1  | COP    | ROCES | SOR | _       | _ | 0 |   | EFI  | FECTIVE | ADDRE | ESS     |   |
| '  | '   | '  | '  |        | ID    |     | "       | 0 |   |   | MODE |         | R     | REGISTE | R |
| 0  | R/M | 0  |    | SOURCE |       |     | STINATI |   | 0 | 0 | 1    | 1       | 1     | 1       | 1 |

## **FMOD**

| 15 | 14  | 13 | 12 | 11                | 10    | 9   | 8                  | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|-----|----|----|-------------------|-------|-----|--------------------|---|---|---|------|---------|-------|--------|---|
| 1  | 1   | 1  | 1  | COF               | ROCES | SOR | 0                  | _ | _ |   | EF   | FECTIVE | ADDRE | ESS    |   |
| '  | '   | '  | '  |                   | ID    |     | "                  | 0 | 0 |   | MODE |         | R     | EGISTE | R |
| 0  | R/M | 0  |    | SOURCE<br>PECIFIE |       |     | STINATI<br>REGISTE |   | 0 | 1 | 0    | 0       | 0     | 0      | 1 |

## **FSGLDIV**

| 15 | 14  | 13 | 12 | 11     | 10          | 9 | 8                 | 7 | 6 | 5 | 4    | 3       | 2     | 1       | 0 |
|----|-----|----|----|--------|-------------|---|-------------------|---|---|---|------|---------|-------|---------|---|
| 1  | 1   | 1  | 1  | COF    | COPROCESSOR |   |                   | 0 |   |   | EF   | FECTIVE | ADDRE | ESS     |   |
| '  | '   | '  | '  |        | ID          |   |                   | " | " |   | MODE |         | R     | REGISTE | R |
| 0  | R/M | 0  |    | SOURCE |             |   | STINATI<br>EGISTE |   | 0 | 1 | 0    | 0       | 1     | 0       | 0 |

## **FREM**

| 15 | 14  | 13 | 12 | 11                | 10     | 9   | 8                 | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|-----|----|----|-------------------|--------|-----|-------------------|---|---|---|------|---------|-------|--------|---|
| 1  | 1   | 1  | 1  | COF               | PROCES | SOR | _                 | 0 |   |   | EF   | FECTIVE | ADDRE | SS     |   |
| '  | '   | '  | '  |                   | ID     |     |                   | " | " |   | MODE |         | R     | EGISTE | R |
| 0  | R/M | 0  |    | SOURCE<br>PECIFIE |        |     | STINATI<br>EGISTE |   | 0 | 1 | 0    | 0       | 1     | 0      | 1 |

## **FSCALE**

| 15 | 14  | 13 | 12 | 11                | 10    | 9   | 8                  | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|-----|----|----|-------------------|-------|-----|--------------------|---|---|---|------|---------|-------|--------|---|
| 4  | 4   | 4  | 1  | COF               | ROCES | SOR |                    |   |   |   | EF   | FECTIVE | ADDRE | SS     |   |
| 1  | '   | '  | '  |                   | ID    |     |                    | 0 | " |   | MODE |         | R     | EGISTE | R |
| 0  | R/M | 0  |    | SOURCE<br>PECIFIE |       |     | STINATI<br>REGISTE |   | 0 | 1 | 0    | 0       | 1     | 1      | 0 |

## **FSGLMUL**

| 15 | 14  | 13 | 12 | 11                | 10          | 9   | 8                 | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|-----|----|----|-------------------|-------------|-----|-------------------|---|---|---|------|---------|-------|--------|---|
| 1  | 1   | 1  | 1  | COF               | PROCES      | SOR | _                 | _ | 0 |   | EFI  | FECTIVE | ADDRE | ESS    |   |
| '  | '   | '  | '  |                   | COPROCESSOR |     |                   | 0 | U |   | MODE |         | R     | EGISTE | R |
| 0  | R/M | 0  |    | SOURCE<br>PECIFIE |             |     | STINATI<br>EGISTE |   | 0 | 1 | 0    | 0       | 1     | 1      | 1 |

## **FSINCOS**

| 15 | 14     | 13 | 12 | 11                  | 10    | 9      | 8       | 7  | 6 | 5 | 4    | 3       | 2       | 1       | 0  |
|----|--------|----|----|---------------------|-------|--------|---------|----|---|---|------|---------|---------|---------|----|
| 1  | 1      | 1  | 1  | COF                 | ROCES | SOR    | _       | _  | 0 |   | EF   | FECTIVE | ADDRE   | SS      |    |
| '  | '      | '  | '  |                     | ID    |        |         | "  | 0 |   | MODE |         | R       | EGISTE  | R  |
| 0  | R/M    | 0  | ;  | SOURCE              |       |        | STINATI | ON | 0 | 1 | 1    | 0       | DE      | STINATI | ON |
| U  | IX/IVI | 0  | S  | SOURCE<br>SPECIFIER | R     | EGISTE | R       |    | ' | ' | "    | REC     | SISTER, | FPc     |    |

## **FCMP**

|   | 15 | 14  | 13 | 12 | 11     | 10    | 9   | 8                 | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|---|----|-----|----|----|--------|-------|-----|-------------------|---|---|---|------|---------|-------|--------|---|
| Γ | 1  | 1   | 1  | 1  | COF    | ROCES | SOR | 0                 | _ | 0 |   | EF   | FECTIVE | ADDRE | SS     |   |
|   | ı  | '   | '  | '  |        | ID    |     | 0                 | " | 0 |   | MODE |         | R     | EGISTE | R |
|   | 0  | R/M | 0  |    | SOURCE |       |     | STINATI<br>EGISTE |   | 0 | 1 | 1    | 1       | 0     | 0      | 0 |

## **FTST**

| 15 | 14  | ŀ | 13 | 12 | 11                | 10          | 9 | 8                 | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|-----|---|----|----|-------------------|-------------|---|-------------------|---|---|---|------|---------|-------|--------|---|
| 1  | 1   |   | 1  | 1  | COP               | COPROCESSOR |   |                   | _ | _ |   | EF   | FECTIVE | ADDRE | SS     |   |
| '  | '   |   | '  | '  |                   | ID          |   | "                 | " | " |   | MODE |         | R     | EGISTE | R |
| 0  | R/N | И | 0  |    | SOURCE<br>PECIFIE | JRCE DES    |   | STINATI<br>EGISTE | - | 0 | 1 | 1    | 1       | 0     | 1      | 0 |

## **FABS**

| 15 | 14  | 13 | 12 | 11  | 10        | 9   | 8                 | 7 | 6 | 5 | 4    | 3      | 2     | 1      | 0 |
|----|-----|----|----|-----|-----------|-----|-------------------|---|---|---|------|--------|-------|--------|---|
| 1  | 1   | 1  | 1  | COF | ROCES     | SOR | _                 | 0 | 0 |   | EF   | ECTIVE | ADDRE | SS     |   |
|    | '   | '  | '  |     | ID        |     |                   | 0 | 0 |   | MODE |        | R     | EGISTE | R |
| 0  | R/M | 0  |    |     | SOURCE DE |     | STINATI<br>EGISTE |   |   |   | (    | OPMODI | Ξ     |        |   |

## **FADD**

| 15 | 14  | 13 | 12 | 11        | 10    | 9   | 8                  | 7 | 6 | 5 | 4    | 3      | 2     | 1      | 0 |
|----|-----|----|----|-----------|-------|-----|--------------------|---|---|---|------|--------|-------|--------|---|
| 1  | 1   | 1  | 1  | COF       | ROCES | SOR |                    | 0 | 0 |   | EF   | ECTIVE | ADDRE | SS     |   |
| 1  | '   | '  | '  |           | ID    |     |                    | 0 | 0 |   | MODE |        | R     | EGISTE | R |
| 0  | R/M | 0  |    | SOURCE DI |       |     | STINATI<br>REGISTE |   |   |   | (    | OPMOD  | E     |        |   |

## **FDIV**

| 15 | 14  | 13 | 12 | 11     | 10                | 9 | 8       | 7 | 6 | 5 | 4    | 3      | 2     | 1      | 0 |
|----|-----|----|----|--------|-------------------|---|---------|---|---|---|------|--------|-------|--------|---|
| 1  | 1   | 1  | 1  | COP    | COPROCESSOR<br>ID |   |         | _ | 0 |   | EFF  | ECTIVE | ADDRE | SS     |   |
| '  | '   | '  | '  |        | ID                |   | "       | " | 0 |   | MODE |        | R     | EGISTE | R |
| 0  | R/M | 0  |    | SOURCE |                   |   | STINATI |   |   |   | (    | PMODE  | Ē     |        |   |

## **FMOVE**

#### DATA REGISTER, EFFECTIVE ADDRESS TO REGISTER

|   | 15 | 14  | 13 | 12 | 11                | 10    | 9   | 8                  | 7 | 6 | 5 | 4    | 3      | 2     | 1      | 0 |
|---|----|-----|----|----|-------------------|-------|-----|--------------------|---|---|---|------|--------|-------|--------|---|
|   | 1  | 1   | 1  | 1  | COP               | ROCES | SOR | 0                  | 0 | 0 |   | EFF  | ECTIVE | ADDRE | SS     |   |
|   | '  | '   | '  | '  | ID                |       |     | "                  | " |   |   | MODE |        | R     | EGISTE | R |
| Ī | 0  | R/M | 0  |    | SOURCE<br>PECIFIE |       |     | STINATI<br>REGISTE |   |   |   | (    | PMODI  | E     |        |   |

## **FMUL**

| 15 | 14  | 13 | 12 | 11                | 10    | 9   | 8                 | 7 | 6 | 5 | 4    | 3      | 2        | 1      | 0 |
|----|-----|----|----|-------------------|-------|-----|-------------------|---|---|---|------|--------|----------|--------|---|
| 1  | 1   | 1  | 1  | COP               | ROCES | SOR | _                 | 0 | 0 |   | EFF  | ECTIVE | ADDRE    | SS     |   |
| '  | '   | '  | '  |                   | ID    |     | 0                 | U | U |   | MODE |        | R        | EGISTE | R |
| 0  | R/M | 0  | 1  | SOURCE<br>PECIFIE |       | 1   | STINATI<br>EGISTE | - |   |   | (    | PMODE  | <b>=</b> |        |   |

## **FNEG**

| 15 | 14  | 13 | 12 | 11  | 10          | 9 | 8                 | 7 | 6 | 5 | 4    | 3       | 2       | 1       | 0 |
|----|-----|----|----|-----|-------------|---|-------------------|---|---|---|------|---------|---------|---------|---|
| 1  | 1   | 1  | 1  | COF | COPROCESSOR |   |                   | _ | 0 |   | EFF  | FECTIVE | E ADDRE | ESS     |   |
| '  | '   | '  | '  |     | ID          |   | 0                 | " |   |   | MODE |         | F       | REGISTE | R |
| 0  | R/M | 0  | 1  |     | SOURCE DI   |   | STINATI<br>EGISTE | - |   |   | (    | OPMOD   | E       |         |   |

## **FSQRT**

|   | 15 | 14  | 13 | 12 | 11                | 10          | 9 | 8       | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|---|----|-----|----|----|-------------------|-------------|---|---------|---|---|---|------|---------|-------|--------|---|
| Ī | 1  | 1   | 1  | 1  | COF               | COPROCESSOR |   |         | _ | 0 |   | EF   | FECTIVE | ADDRE | SS     |   |
|   | 1  | '   | '  | '  | ID                |             |   | "       | " | " |   | MODE |         | R     | EGISTE | R |
|   | 0  | R/M | 0  |    | SOURCE<br>PECIFIE |             | 1 | STINATI | - |   |   | (    | OPMODI  | Ē     |        |   |

## **FSUB**

| 15 | 14  | 13 | 12 | 11  | 10        | 9   | 8                 | 7 | 6 | 5 | 4    | 3      | 2     | 1       | 0 |
|----|-----|----|----|-----|-----------|-----|-------------------|---|---|---|------|--------|-------|---------|---|
| 1  | 1   | 1  | 1  | COP | ROCES     | SOR | _                 | _ | _ |   | EFF  | ECTIVE | ADDRE | ESS     |   |
| '  | '   | '  | '  |     | ID        |     | "                 | 0 | " |   | MODE |        | F     | REGISTE | R |
| 0  | R/M | 0  |    |     | OURCE DES |     | STINATI<br>EGISTE | - |   |   | (    | PMODE  | ≣     |         |   |

#### **FMOVE**

#### DATA REGISTER, REGISTER TO MEMORY

| 15 | 14 | 13 | 12 | 11      | 10 | 9  | 8      | 7  | 6 | 5 | 4     | 3      | 2     | 1       | 0 |
|----|----|----|----|---------|----|----|--------|----|---|---|-------|--------|-------|---------|---|
| 1  | 1  | 1  | 1  | 0       | _  | 1  | 0      | _  | 0 |   | EFF   | ECTIVE | ADDRE | ESS     |   |
| '  | '  | '  | '  | "       | "  | '  | "      | "  | 0 |   | MODE  |        | F     | REGISTE | R |
| 0  | 1  | 1  | ;  | SOURCE  |    | DE | STINAT | ON |   |   | K     | -FACTO | R     |         |   |
| 0  | '  | '  | S  | PECIFIE | R  | R  | EGISTE | R  |   |   | (IF I | REQUIR | ED)   |         |   |

## **FMOVE**

#### SYSTEM CONTROL REGISTER

|   | 15 | 14 | 13 | 12 | 11               | 10    | 9   | 8 | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|---|----|----|----|----|------------------|-------|-----|---|---|---|---|------|---------|-------|--------|---|
| Γ | 1  | 1  | 1  | 1  | COP              | ROCES | SOR | _ | 0 | _ |   | EF   | FECTIVE | ADDRE | SS     |   |
|   | '  | !  | '  | '  |                  | ID    |     | " | 0 | " |   | MODE |         | R     | EGISTE | R |
|   | 1  | 0  | dr |    | EGISTE<br>SELECT |       | 0   | 0 | 0 | 0 | 0 | 0    | 0       | 0     | 0      | 0 |

## **FMOVEM**

## **CONTROL REGISTERS**

| 15 | 14 | 13 | 12 | 11               | 10          | 9   | 8 | 7 | 6 | 5 | 4          | 3       | 2     | 1            | 0 |
|----|----|----|----|------------------|-------------|-----|---|---|---|---|------------|---------|-------|--------------|---|
| 1  | 1  | 1  | 1  | COF              | ROCES<br>ID | SOR | 0 | 0 | 0 |   | EF<br>MODE | FECTIVE | ADDRE | SS<br>EGISTE | R |
| 1  | 0  | dr | R  | EGISTE<br>SELECT |             | 0   | 0 | 0 | 0 | 0 | 0          | 0       | 0     | 0            | 0 |

## **FMOVEM**

#### **DATA REGISTERS**

|   | 15 | 14 | 13 | 12 | 11  | 10          | 9   | 8                                         | 7               | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---|----|----|----|----|-----|-------------|-----|-------------------------------------------|-----------------|---|---|---|---|---|---|---|
|   | 1  | 1  | 1  | 1  | COF | ROCES<br>ID | SOR | SOR 0 0 0 EFFECTIVE ADDRESS MODE REGISTER |                 |   |   | R |   |   |   |   |
| Ī | 1  | 1  | dr | MC | DE  | 0           | 0   | 0                                         | 0 REGISTER LIST |   |   |   |   |   |   |   |

# cpGEN

| 1 | 5                                                                    | 14 | 13 | 12 | 11                            | 10     | 9      | 8      | 7     | 6     | 5     | 4    | 3 | 2      | 1  | 0 |
|---|----------------------------------------------------------------------|----|----|----|-------------------------------|--------|--------|--------|-------|-------|-------|------|---|--------|----|---|
|   | 1                                                                    | 1  | 1  | 1  | 1 COPROCESSOR 0 0 0 EFFECTIVE |        |        |        |       |       |       |      |   |        | SS |   |
|   | '                                                                    | '  | '  | '  |                               | ID     |        | 0      | "     | 0     |       | MODE |   | EGISTE | R  |   |
|   |                                                                      |    | •  | •  | C                             | OPROCE | SSOR I | D-DEPE | NDENT | COMMA | ND WO | RD   |   | •      |    |   |
|   | OPTIONAL EFFECTIVE ADDRESS OR COPROCESSOR ID-DEFINED EXTENSION WORDS |    |    |    |                               |        |        |        |       |       |       |      |   |        |    |   |

## **FScc**

| 15 | 14 | 13 | 12 | 11  | 10    | 9   | 8 | 7 | 6    | 5                     | 4   | 3                 | 2 | 1 | 0 |
|----|----|----|----|-----|-------|-----|---|---|------|-----------------------|-----|-------------------|---|---|---|
| 1  | 1  | 1  | 1  | COF | ROCES | SOR | 0 | 0 | 1    |                       | EFI | EFFECTIVE ADDRESS |   |   |   |
| '  | '  | '  | '  |     |       |     |   |   | MODE |                       | R   | EGISTE            | R |   |   |
| 0  | 0  | 0  | 0  | 0   | 0     | 0   | 0 | 0 | 0    | CONDITIONAL PREDICATE |     |                   |   |   |   |

# cpScc

| 15 | 14 | 13  | 12      | 11     | 10      | 9       | 8      | 7      | 6        | 5     | 4      | 3      | 2        | 1       | 0 |
|----|----|-----|---------|--------|---------|---------|--------|--------|----------|-------|--------|--------|----------|---------|---|
| 1  | 1  | 1   | 1       | COF    | ROCES   | SOR     | 0      | 0      | 1        |       | EFF    | ECTIVE | ADDRE    | SS      |   |
| '  | '  | '   | '       |        | ID      |         | "      | "      | '        |       | MODE   |        | R        | EGISTE  | R |
| 0  | 0  | 0   | 0       | 0      | 0       | 0       | 0      | 0      | 0        |       | COPRO  | CESSO  | R ID COI | NDITION |   |
|    |    | OPT | IONAL E | FFECTI | VE ADDI | RESS OF | R COPR | OCESSO | OR ID-DE | FINED | EXTENS | ION WC | RDS      |         |   |

## **FBcc**

| 15 | 14                                                        | 13 | 12       | 11     | 10           | 9     | 8        | 7       | 6      | 5       | 4        | 3       | 2       | 1 | 0 |
|----|-----------------------------------------------------------|----|----------|--------|--------------|-------|----------|---------|--------|---------|----------|---------|---------|---|---|
| 1  | 1                                                         | 1  | 1        | COP    | ROCESS<br>ID | SOR   | 0        | 1       | SIZE   | C       | CONDITIO | ONAL PF | REDICAT | Έ |   |
|    |                                                           | 1  | 6-BIT DI | SPLACE | MENT O       | R MOS | T SIGNIF | ICANT \ | WORD O | F 32-BI | T DISPLA | CEMEN   | ΙT      |   |   |
|    | LEAST SIGNIFICANT WORD OF 32-BIT DISPLACEMENT (IF NEEDED) |    |          |        |              |       |          |         |        |         |          |         |         |   |   |

# срВсс

| 15 | 14 | 13 | 12 | 11     | 10          | 9      | 8       | 7       | 6      | 5     | 4     | 3      | 2       | 1       | 0 |
|----|----|----|----|--------|-------------|--------|---------|---------|--------|-------|-------|--------|---------|---------|---|
| 1  | 1  | 1  | 1  | COP    | ROCES<br>ID | SOR    | 0       | 1       | SIZE   |       | COPRO | CESSOF | R ID CO | NDITION |   |
|    |    |    |    | OPTION | NAL COF     | PROCES | SSOR ID | -DEFINE | D EXTE | NOISN | WORDS |        |         |         |   |
|    |    |    |    |        |             |        | WOR     | D OR    |        |       |       |        |         |         |   |
|    |    |    |    |        |             | LONG-  | WORD D  | ISPLAC  | EMENT  |       |       |        |         |         |   |

# cpSAVE

| 15 | 14 | 13 | 12 | 11  | 10    | 9   | 8 | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|----|----|----|-----|-------|-----|---|---|---|---|------|---------|-------|--------|---|
| 1  | 1  | 1  | 1  | COF | ROCES | SOR | 1 | _ | _ |   | EFI  | FECTIVE | ADDRE | SS     |   |
| '  | '  | '  | '  |     | ID    |     | ' | " | " |   | MODE |         | R     | EGISTE | R |

# **FSAVE**

| 15 | 14 | 13 | 12 | 11  | 10    | 9   | 8 | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0 |
|----|----|----|----|-----|-------|-----|---|---|---|---|------|---------|-------|--------|---|
| 1  | 1  | 1  | 1  | COF | ROCES | SOR | 1 | _ | _ |   | EF   | FECTIVE | ADDRE | SS     |   |
| '  | '  | '  | '  |     | ID    |     | ' | " | " |   | MODE |         | R     | EGISTE | R |

# cpRESTORE

| 15 | 14 | 13 | 12 | 11  | 10    | 9   | 8 | 7 | 6 | 5 | 4    | 3       | 2     | 1      | 0  |
|----|----|----|----|-----|-------|-----|---|---|---|---|------|---------|-------|--------|----|
| 1  | 1  | 1  | 1  | COF | ROCES | SOR | 1 | 0 | 1 |   | EFI  | FECTIVE | ADDRE | SS     |    |
| 1  | '  | '  | '  |     | ID    |     | ' | 0 | ' |   | MODE |         | R     | EGISTE | :R |

## **FRESTORE**

| 15 | 14 | 13 | 12 | 11  | 10    | 9   | 8 | 7 | 6 | 5 | 4    | 3      | 2     | 1      | 0 |
|----|----|----|----|-----|-------|-----|---|---|---|---|------|--------|-------|--------|---|
| 1  | 1  | 1  | 1  | COF | ROCES | SOR | 1 | _ | 4 |   | EFI  | ECTIVE | ADDRE | SS     |   |
| '  | '  | '  | '  |     | ID    |     | ' | " | ' |   | MODE |        | R     | EGISTE | R |

## **FDBcc**

| 15 | 14 | 13        | 12 | 11  | 10          | 9    | 8        | 7     | 6   | 5 | 4    | 3       | 2      | 1                | 0 |
|----|----|-----------|----|-----|-------------|------|----------|-------|-----|---|------|---------|--------|------------------|---|
| 1  | 1  | 1         | 1  | COF | ROCES<br>ID | SOR  | 0        | 0     | 1   | 0 | 0    | 1       | R      | COUNT<br>REGISTE |   |
| 0  | 0  | 0 0 0 0 0 |    |     |             |      | 0        | 0     | 0   |   | CONI | DITIONA | L PRED | ICATE            |   |
|    |    |           |    |     |             | 16-l | BIT DISF | LACEM | ENT | • |      |         |        |                  |   |

## cpDBcc

| 15 | 14                  | 13 | 12                                              | 11  | 10          | 9   | 8 | 7 | 6 | 5 | 4     | 3      | 2        | 1       | 0 |
|----|---------------------|----|-------------------------------------------------|-----|-------------|-----|---|---|---|---|-------|--------|----------|---------|---|
| 1  | 1                   | 1  | 1                                               | COF | ROCES<br>ID | SOR | 0 | 0 | 1 | 0 | 0     | 1      | R        | REGISTE | R |
| 0  | 0                   | 0  | 0                                               | 0   | 0           | 0   | 0 | 0 | 0 |   | COPRO | CESSOI | R ID COI | NDITION |   |
|    |                     |    | OPTIONAL COPROCESSOR ID-DEFINED EXTENSION WORDS |     |             |     |   |   |   |   |       |        |          |         |   |
|    | 16-BIT DISPLACEMENT |    |                                                 |     |             |     |   |   |   |   |       |        |          |         |   |

## **FTRAPcc**

| 15 | 14 | 13 | 12      | 11    | 10          | 9       | 8       | 7      | 6       | 5        | 4        | 3       | 2      | 1     | 0 |
|----|----|----|---------|-------|-------------|---------|---------|--------|---------|----------|----------|---------|--------|-------|---|
| 1  | 1  | 1  | 1       | COF   | ROCES<br>ID | SOR     | 0       | 0      | 1       | 1        | 1        | 1       |        | MODE  |   |
| 0  | 0  | 0  | 0       | 0     | 0           | 0       | 0       | 0      | 0       |          | CONI     | DITIONA | L PRED | ICATE |   |
|    |    | 16 | -BIT OP | ERAND | OR MOS      | ST SIGN | IFICANT | WORD   | OF 32-B | IT OPEF  | RAND (IF | NEEDE   | D)     |       |   |
|    |    |    |         | LEAST | SIGNIFI     | CANT W  | ORD OR  | 32-BIT | OPERAI  | ND (IF N | EEDED)   |         |        |       |   |

## **cpTRAPcc**

| 15 | 14                   | 13 | 12 | 11    | 10          | 9      | 8       | 7      | 6      | 5       | 4     | 3     | 2       | 1       | 0 |
|----|----------------------|----|----|-------|-------------|--------|---------|--------|--------|---------|-------|-------|---------|---------|---|
| 1  | 1                    | 1  | 1  | COF   | ROCES<br>ID | SOR    | 0       | 0      | 1      | 1       | 1     | 1     |         | OPMODE  |   |
| 0  | 0                    | 0  | 0  | 0     | 0           | 0      | 0       | 0      | 0      |         | COPRO | CESSO | R ID CO | NDITION |   |
|    |                      |    |    | OPTIO | VAL CO      | PROCES | SOR ID- | DEFINE | D EXTE | NSION \ | NORDS |       |         |         |   |
|    | OPTIONAL WORD        |    |    |       |             |        |         |        |        |         |       |       |         |         |   |
|    | OR LONG-WORD OPERAND |    |    |       |             |        |         |        |        |         |       |       |         |         |   |

## **FNOP**

| 15 | 14 | 13 | 12 | 11  | 10          | 9   | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|-----|-------------|-----|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 1  | COF | ROCES<br>ID | SOR | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 0  | 0  | 0  | 0  | 0   | 0           | 0   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

# APPENDIX A PROCESSOR INSTRUCTION SUMMARY

This appendix provides a quick reference of the M68000 family instructions. The organization of this section is by processors and their addressing modes. All references to the MC68000, MC68020, and MC68030 include references to the corresponding embedded controllers, MC68EC000, MC68EC020, and MC68EC030. All references to the MC68040 include the MC68LC040 and MC68EC040. This referencing applies throughout this section unless otherwise specified. Table A-1 lists the M68000 family instructions by mnemonic and indicates which processors they apply to.

Table A-1. M68000 Family Instruction Set And Processor Cross-Reference

| Mnemonic                | 68000 | 68008 | 68010 | 68020 | 68030 | 68040 | 68881/<br>68882 | 68851 | CPU32 |
|-------------------------|-------|-------|-------|-------|-------|-------|-----------------|-------|-------|
|                         | X     | X     | X     | X     | X     | X     | 00002           | 00031 | X     |
| ABCD                    |       |       | 1     |       |       |       |                 |       |       |
| ADD                     | X     | Х     | Х     | X     | Х     | Х     |                 |       | Х     |
| ADDA                    | Х     | Х     | Х     | Х     | Х     | Х     |                 |       | Х     |
| ADDI                    | Х     | Х     | X     | Х     | Х     | Х     |                 |       | Х     |
| ADDQ                    | Х     | Х     | X     | X     | X     | Х     |                 |       | Х     |
| ADDX                    | Х     | Х     | Х     | Х     | Х     | X     |                 |       | Х     |
| AND                     | Х     | Х     | Х     | Х     | X     | Х     |                 |       | Х     |
| ANDI                    | Х     | Х     | Х     | Х     | Х     | Х     |                 |       | Х     |
| ANDI to CCR             | Х     | Х     | Х     | Х     | Х     | Х     |                 |       | Х     |
| ANDI to SR <sup>1</sup> | Х     | Х     | Х     | Х     | Х     | Х     |                 |       | Х     |
| ASL, ASR                | Х     | Х     | Х     | Х     | X     | X     |                 |       | Х     |
| Bcc                     | Х     | Х     | Х     | Х     | X     | Х     |                 |       | Х     |
| BCHG                    | Х     | Х     | Х     | Х     | Х     | X     |                 |       | Х     |
| BCLR                    | Х     | Х     | Х     | Х     | X     | X     |                 |       | Х     |
| BFCHG                   |       |       |       | Х     | X     | Х     |                 |       |       |
| BFCLR                   |       |       |       | Х     | Х     | Х     |                 |       |       |
| BFEXTS                  |       |       |       | Х     | Х     | Х     |                 |       |       |
| BFEXTU                  |       |       |       | Х     | Х     | Х     |                 |       |       |
| BFFFO                   |       |       |       | Х     | Х     | Х     |                 |       |       |

Table A-1. M68000 Family Instruction Set And Processor Cross-Reference (Continued)

| Mnemonic            | 68000 | 68008 | 68010 | 68020 | 68030 | 68040 | 68881/<br>68882 | 68851 | CPU32 |
|---------------------|-------|-------|-------|-------|-------|-------|-----------------|-------|-------|
| BFINS               |       |       |       | X     | X     | X     |                 |       |       |
| BFSET               |       |       |       | Х     | X     | X     |                 |       |       |
| BFTST               |       |       |       | Х     | Х     | Х     |                 |       |       |
| BGND                |       |       |       |       |       |       |                 |       | Х     |
| BKPT                |       |       | Х     | Х     | Х     | Х     |                 |       | Х     |
| BRA                 | Х     | Х     | Х     | Х     | Х     | Х     |                 |       | Х     |
| BSET                | Х     | Х     | Х     | Х     | Х     | Х     |                 |       | Х     |
| BSR                 | Х     | Х     | Х     | Х     | Х     | Х     |                 |       | Х     |
| BTST                | Х     | Х     | Х     | Х     | Х     | Х     |                 |       | Х     |
| CALLM               |       |       |       | Х     |       |       |                 |       |       |
| CAS, CAS2           |       |       |       | Х     | Х     | Х     |                 |       |       |
| CHK                 | Х     | Х     | Х     | Х     | Х     | Х     |                 |       | Х     |
| CHK2                |       |       |       | Х     | Х     | Х     |                 |       | Х     |
| CINV <sup>1</sup>   |       |       |       |       |       | Х     |                 |       |       |
| CLR                 | Х     | X     | X     | X     | Х     | Х     |                 |       | Х     |
| CMP                 | Х     | Х     | Х     | Х     | Х     | Х     |                 |       | Х     |
| CMPA                | Х     | Х     | Х     | Х     | Х     | Х     |                 |       | Х     |
| CMPI                | Х     | Х     | Х     | Х     | Х     | Х     |                 |       | Х     |
| СМРМ                | Х     | Х     | Х     | Х     | Х     | Х     |                 |       | Х     |
| CMP2                |       |       |       | Х     | Х     | Х     |                 |       | Х     |
| срВсс               |       |       |       | Х     | Х     |       |                 |       |       |
| cpDBcc              |       |       |       | Х     | Х     |       |                 |       |       |
| cpGEN               |       |       |       | X     | X     |       |                 |       |       |
| cpRESTORE1          |       |       |       | Х     | Х     |       |                 |       |       |
| cpSAVE <sup>1</sup> |       |       |       | Х     | Х     |       |                 |       |       |
| cpScc               |       |       |       | X     | X     |       |                 |       |       |
| cpTRAPcc            |       |       |       | X     | Х     |       |                 |       |       |
| CPUSH <sup>1</sup>  |       |       |       |       |       | Х     |                 |       |       |
| DBcc                | X     | X     | X     | X     | X     | X     |                 |       | X     |
| DIVS                | X     | X     | X     | Х     | Х     | X     |                 |       | X     |
| DIVSL               |       |       |       | Х     | Х     | Х     |                 |       | X     |
| DIVU                | X     | Х     | X     | Х     | Х     | Х     |                 |       | Х     |
| DIVUL               |       |       |       | Х     | Х     | Х     |                 |       | X     |

Table A-1. M68000 Family Instruction Set And Processor Cross-Reference (Continued)

|              |       |       |       |       |       |                                        | 68881/ |       |       |
|--------------|-------|-------|-------|-------|-------|----------------------------------------|--------|-------|-------|
| Mnemonic     | 68000 | 68008 | 68010 | 68020 | 68030 | 68040                                  | 68882  | 68851 | CPU32 |
| EOR          | Х     | Х     | Х     | Х     | Х     | Х                                      |        |       | Х     |
| EORI         | Х     | Х     | Х     | Х     | Х     | X                                      |        |       | Х     |
| EORI to CCR  | Х     | Х     | Х     | Х     | Х     | Х                                      |        |       | Х     |
| EORI to SR1  | Х     | X     | Х     | Х     | Х     | Х                                      |        |       | X     |
| EXG          | Х     | Х     | Х     | Х     | Х     | Х                                      |        |       | Х     |
| EXT          | Х     | Х     | Х     | Х     | Х     | Х                                      |        |       | Х     |
| EXTB         |       |       |       | Х     | Х     | Х                                      |        |       | Х     |
| FABS         |       |       |       |       |       | X <sup>2</sup>                         | Х      |       |       |
| FSABS,       |       |       |       |       |       | X <sup>2</sup>                         |        |       |       |
| FDABS        |       |       |       |       |       | λ-                                     |        |       |       |
| FACOS        |       |       |       |       |       | 2,3                                    | Х      |       |       |
| FADD         |       |       |       |       |       | X <sup>2</sup>                         | Х      |       |       |
| FSADD,       |       |       |       |       |       | \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ |        |       |       |
| FDADD        |       |       |       |       |       | X <sup>2</sup>                         |        |       |       |
| FASIN        |       |       |       |       |       | 2,3                                    | Х      |       |       |
| FATAN        |       |       |       |       |       | 2,3                                    | Х      |       |       |
| FATANH       |       |       |       |       |       | 2,3                                    | Х      |       |       |
| FBcc         |       |       |       |       |       | X <sup>2</sup>                         | Х      |       |       |
| FCMP         |       |       |       |       |       | X <sup>2</sup>                         | Х      |       |       |
| FCOS         |       |       |       |       |       | 2,3                                    | X      |       |       |
| FCOSH        |       |       |       |       |       | 2,3                                    | X      |       |       |
| FDBcc        |       |       |       |       |       | X <sup>2</sup>                         | Х      |       |       |
| FDIV         |       |       |       |       |       | X <sup>2</sup>                         | Х      |       |       |
| FSDIV, FDDIV |       |       |       |       |       | X <sup>2</sup>                         |        |       |       |
| FETOX        |       |       |       |       |       | 2,3                                    | X      |       |       |
| FETOXM1      |       |       |       |       |       | 2,3                                    | X      |       |       |
| FGETEXP      |       |       |       |       |       | 2,3                                    | X      |       |       |
| FGETMAN      |       |       |       |       |       | 2,3                                    | X      |       |       |
| FINT         |       |       |       |       |       | 2,3                                    | Х      |       |       |
| FINTRZ       |       |       |       |       |       | 2,3                                    | Х      |       |       |
| FLOG10       |       |       |       |       |       | 2,3                                    | Х      |       |       |
| FLOG2        |       |       |       |       |       | 2,3                                    | Х      |       |       |
| FLOGN        |       |       |       |       |       | 2,3                                    | Х      |       |       |

Table A-1. M68000 Family Instruction Set And Processor Cross-Reference (Continued)

| Mnemonic              | 68000 | 68008 | 68010 | 68020 | 68030 | 68040          | 68881/<br>68882 | 68851 | CPU32 |
|-----------------------|-------|-------|-------|-------|-------|----------------|-----------------|-------|-------|
| FLOGNP1               | 00000 | 00000 | 00010 | 00020 | 00000 | 2,3            | 00002           | 00001 | 0.002 |
| FMOD                  |       |       |       |       |       | 2,3            | X               |       |       |
| FMOVE                 |       |       |       |       |       | X <sup>2</sup> | X               |       |       |
| FSMOVE,               |       |       |       |       |       |                |                 |       |       |
| FDMOVE                |       |       |       |       |       | X <sup>2</sup> |                 |       |       |
| FMOVECR               |       |       |       |       |       | 2,3            | X               |       |       |
| FMOVEM                |       |       |       |       |       | X <sup>2</sup> | Х               |       |       |
| FMUL                  |       |       |       |       |       | X <sup>2</sup> | X               |       |       |
| FSMUL,                |       |       |       |       |       |                |                 |       |       |
| FDMUL                 |       |       |       |       |       | X <sup>2</sup> |                 |       |       |
| FNEG                  |       |       |       |       |       | X <sup>2</sup> | X               |       |       |
| FSNEG,                |       |       |       |       |       |                |                 |       |       |
| FDNEG                 |       |       |       |       |       | X <sup>2</sup> |                 |       |       |
| FNOP                  |       |       |       |       |       | X <sup>2</sup> | Х               |       |       |
| FREM                  |       |       |       |       |       | 2,3            | X               |       |       |
| FRESTORE <sup>1</sup> |       |       |       |       |       | X <sup>2</sup> | Х               |       |       |
| FSAVE*                |       |       |       |       |       | X <sup>2</sup> | X               |       |       |
| FSCALE                |       |       |       |       |       | 2,3            | X               |       |       |
| FScc                  |       |       |       |       |       | X <sup>2</sup> | Х               |       |       |
| FSGLDIV               |       |       |       |       |       | 2,3            | X               |       |       |
| FSGLMUL               |       |       |       |       |       | 2,3            | X               |       |       |
| FSIN                  |       |       |       |       |       | 2,3            | Х               |       |       |
| FSINCOS               |       |       |       |       |       | 2,3            | Х               |       |       |
| FSINH                 |       |       |       |       |       | 2,3            | Х               |       |       |
| FSQRT                 |       |       |       |       |       | X <sup>2</sup> | Х               |       |       |
| FSSQRT,               |       |       |       |       |       | X <sup>2</sup> |                 |       |       |
| FDSQRT                |       |       |       |       |       | X-             |                 |       |       |
| FSUB                  |       |       |       |       |       | X <sup>2</sup> | Х               |       |       |
| FSSUB,                |       |       |       |       |       | \\\\2          |                 |       |       |
| FDSUB                 |       |       |       |       |       | X <sup>2</sup> |                 |       |       |
| FTAN                  |       |       |       |       |       | 2,3            | Х               |       |       |
| FTANH                 |       |       |       |       |       | 2,3            | Х               |       |       |
| FTENTOX               |       |       |       |       |       | 2,3            | Х               |       |       |
| FTRAPcc               |       |       |       |       |       | X <sup>2</sup> | Х               |       |       |
| FTST                  |       |       |       |       |       | X <sup>2</sup> | Х               |       |       |

Table A-1. M68000 Family Instruction Set And Processor Cross-Reference (Continued)

| Mnemonic                     | 68000 | 68008 | 68010 | 68020 | 68030 | 68040 | 68881/<br>68882 | 68851 | CPU32 |
|------------------------------|-------|-------|-------|-------|-------|-------|-----------------|-------|-------|
| FTWOTOX                      |       |       |       |       |       | 2,3   | Х               |       |       |
| ILLEGAL                      | Х     | Х     | Х     | X     | X     | X     |                 |       | Х     |
| JMP                          | Х     | Х     | Х     | Х     | X     | X     |                 |       | X     |
| JSR                          | Х     | Х     | Х     | Х     | Х     | Х     |                 |       | X     |
| LEA                          | X     | Х     | Х     | Х     | Х     | Х     |                 |       | Х     |
| LINK                         | Х     | Х     | Х     | Х     | Х     | Х     |                 |       | Х     |
| LPSTOP                       |       |       |       |       |       |       |                 |       | Х     |
| LSL,LSR                      | Х     | Х     | Х     | Х     | Х     | Х     |                 |       | Х     |
| MOVE                         | Х     | Х     | Х     | Х     | Х     | Х     |                 |       | Х     |
| MOVEA                        | Х     | Х     | Х     | Х     | Х     | X     |                 |       | Х     |
| MOVE from CCR                |       |       | Х     | X     | X     | X     |                 |       | Х     |
| MOVE to CCR                  | Х     | Х     | Х     | Х     | X     | Х     |                 |       | Х     |
| MOVE<br>from SR <sup>1</sup> | 4     | 4     | Х     | Х     | Х     | Х     |                 |       | Х     |
| MOVE<br>to SR <sup>1</sup>   | Х     | Х     | Х     | Х     | Х     | Х     |                 |       | Х     |
| MOVE USP1                    | Х     | Х     | X     | Х     | Х     | Х     |                 |       | Х     |
| MOVE16                       |       |       |       |       |       | Х     |                 |       |       |
| MOVEC <sup>1</sup>           |       |       | Х     | Х     | Х     | Х     |                 |       | Х     |
| MOVEM                        | Х     | Х     | Х     | Х     | X     | X     |                 |       | Х     |
| MOVEP                        | Х     | Х     | Х     | Х     | Х     | Х     |                 |       | Х     |
| MOVEQ                        | Х     | Х     | Х     | Х     | Х     | Х     |                 |       | X     |
| MOVES <sup>1</sup>           |       |       | Х     | Х     | Х     | Х     |                 |       | Х     |
| MULS                         | Х     | Х     | Х     | X     | Х     | X     |                 |       | X     |
| MULU                         | Х     | Х     | Х     | Х     | Х     | Х     |                 |       | X     |
| NBCD                         | Х     | Х     | Х     | Х     | Х     | X     |                 |       | Х     |
| NEG                          | Х     | Х     | Х     | Х     | Х     | Х     |                 |       | Х     |
| NEGX                         | Х     | Х     | Х     | Х     | Х     | Х     |                 |       | X     |
| NOP                          | X     | Х     | Х     | Х     | Х     | Х     |                 |       | Х     |
| NOT                          | Х     | Х     | Х     | Х     | Х     | Х     |                 |       | X     |
| OR                           | Х     | Х     | Х     | Х     | Х     | Х     |                 |       | Х     |

Table A-1. M68000 Family Instruction Set And Processor Cross-Reference (Continued)

| Mnemonic               | 68000 | 68008 | 68010 | 68020 | 68030          | 68040 | 68881/<br>68882 | 68851 | CPU32 |
|------------------------|-------|-------|-------|-------|----------------|-------|-----------------|-------|-------|
| ORI                    | Х     | Х     | Х     | Х     | Х              | Х     |                 |       | Х     |
| ORI to CCR             | Х     | Х     | Х     | Х     | X              | X     |                 |       | Х     |
| ORI to SR <sup>1</sup> | Х     | X     | Х     | Х     | X              | X     |                 |       | Х     |
| PACK                   |       |       |       | Х     | Х              | X     |                 |       |       |
| PBcc <sup>1</sup>      |       |       |       |       |                |       |                 | Х     |       |
| PDBcc <sup>1</sup>     |       |       |       |       |                |       |                 | Х     |       |
| PEA                    | Х     | Х     | Х     | Х     | Х              | Х     |                 |       | Х     |
| PFLUSH <sup>1</sup>    |       |       |       |       | X <sup>5</sup> | Х     |                 | Х     |       |
| PFLUSHA <sup>1</sup>   |       |       |       |       | X <sup>5</sup> |       |                 | Х     |       |
| PFLUSHR <sup>1</sup>   |       |       |       |       |                |       |                 | Х     |       |
| PFLUSHS <sup>1</sup>   |       |       |       |       |                |       |                 | Х     |       |
| PLOAD <sup>1</sup>     |       |       |       |       | X <sup>5</sup> |       |                 | Х     |       |
| PMOVE <sup>1</sup>     |       |       |       |       | Х              |       |                 | Х     |       |
| PRESTORE <sup>1</sup>  |       |       |       |       |                |       |                 | Х     |       |
| PSAVE <sup>1</sup>     |       |       |       |       |                |       |                 | X     |       |
| PScc <sup>1</sup>      |       |       |       |       |                |       |                 | X     |       |
| PTEST <sup>1</sup>     |       |       |       |       | X              | X     |                 | X     |       |
| PTRAPcc <sup>1</sup>   |       |       |       |       |                |       |                 | X     |       |
| PVALID                 |       |       |       |       |                |       |                 | X     |       |
| RESET <sup>1</sup>     | X     | X     | Х     | X     | X              | X     |                 |       | X     |
| ROL,ROR                | X     | X     | X     | X     | X              | X     |                 |       | X     |
| ROXL,                  |       |       |       |       |                |       |                 |       |       |
| ROXR                   | X     | X     | X     | X     | X              | X     |                 |       | X     |
| RTD                    |       |       | Х     | Х     | Х              | Х     |                 |       | Х     |
| RTE <sup>1</sup>       | Х     | Х     | Х     | Х     | Х              | Х     |                 |       | Х     |
| RTM                    |       |       |       | Х     |                |       |                 |       |       |
| RTR                    | Х     | Х     | Х     | Х     | Х              | Х     |                 |       | Х     |
| RTS                    | Х     | Х     | Х     | Х     | X              | Х     |                 |       | Х     |
| SBCD                   | Х     | Х     | Х     | Х     | Х              | Х     |                 |       | Х     |
| Scc                    | Х     | Х     | Х     | Х     | Х              | Х     |                 |       | Х     |
| STOP1                  | Х     | Х     | Х     | Х     | Х              | Х     |                 |       | Х     |
| SUB                    | Х     | Х     | Х     | Х     | Х              | Х     |                 |       | Х     |
| SUBA                   | Х     | Х     | Х     | Х     | Х              | Х     |                 |       | Х     |
| SUBI                   | Х     | Х     | Х     | Х     | Х              | Х     |                 |       | Х     |
| SUBQ                   | X     | X     | X     | X     | X              | X     |                 |       | X     |
| SUBX                   | Х     | Х     | Х     | Х     | Х              | Х     |                 |       | Х     |

Table A-1. M68000 Family Instruction Set And Processor Cross-Reference (Concluded)

| Mnemonic | 68000 | 68008 | 68010 | 68020 | 68030 | 68040 | 68881/<br>68882 | 68851 | CPU32 |
|----------|-------|-------|-------|-------|-------|-------|-----------------|-------|-------|
| SWAP     | Х     | Х     | Х     | Х     | X     | Х     |                 |       | Х     |
| TAS      | X     | Х     | Х     | X     | Х     | X     |                 |       | Х     |
| TBLS,    |       |       |       |       |       |       |                 |       | Х     |
| TBLSN    |       |       |       |       |       |       |                 |       | ^     |
| TBLU,    |       |       |       |       |       |       |                 |       | Х     |
| TBLUN    |       |       |       |       |       |       |                 |       | _ ^   |
| TRAP     | Х     | Х     | Х     | Х     | Х     | Х     |                 |       | Х     |
| TRAPcc   |       |       |       | Х     | Х     | X     |                 |       | Х     |
| TRAPV    | X     | Х     | Х     | X     | X     | X     |                 |       | Х     |
| TST      | X     | Х     | Х     | Х     | Х     | X     |                 |       | Х     |
| UNLK     | Х     | Х     | Х     | Х     | Х     | X     |                 |       | Х     |
| UNPK     |       |       |       | Х     | Х     | Х     |                 |       |       |

#### NOTES:

- 1. Privileged (Supervisor) Instruction.
- 2. Not applicable to MC68EC040 and MC68LC040
- 3. These instructions are software supported on the MC68040.
- 4. This instruction is not privileged for the MC68000 and MC68008.
- 5. Not applicable to MC68EC030.

Table A-2 lists the M68000 family instructions by mnemonics, followed by the descriptive name.

Table A-2. M68000 Family Instruction Set

| Mnemonic    | Description                                     |
|-------------|-------------------------------------------------|
| ABCD        | Add Decimal with Extend                         |
| ADD         | Add                                             |
| ADDA        | Address                                         |
| ADDI        | Add Immediate                                   |
| ADDQ        | Add Quick                                       |
| ADDX        | Add with Extend                                 |
| AND         | Logical AND                                     |
| ANDI        | Logical AND Immediate                           |
| ANDI to CCR | AND Immediate to Condition Code Register        |
| ANDI to SR  | AND Immediate to Status Register                |
| ASL, ASR    | Arithmetic Shift Left and Right                 |
| Bcc         | Branch Conditionally                            |
| BCHG        | Test Bit and Change                             |
| BCLR        | Test Bit and Clear                              |
| BFCHG       | Test Bit Field and Change                       |
| BFCLR       | Test Bit Field and Clear                        |
| BFEXTS      | Signed Bit Field Extract                        |
| BFEXTU      | Unsigned Bit Field Extract                      |
| BFFFO       | Bit Field Find First One                        |
| BFINS       | Bit Field Insert                                |
| BFSET       | Test Bit Field and Set                          |
| BFTST       | Test Bit Field                                  |
| BGND        | Enter Background Mode                           |
| BKPT        | Breakpoint                                      |
| BRA         | Branch                                          |
| BSET        | Test Bit and Set                                |
| BSR         | Branch to Subroutine                            |
| BTST        | Test Bit                                        |
| CALLM       | CALL Module                                     |
| CAS         | Compare and Swap Operands                       |
| CAS2        | Compare and Swap Dual Operands                  |
| CHK         | Check Register Against Bound                    |
| CHK2        | Check Register Against Upper and Lower Bounds   |
| CINV        | Invalidate Cache Entries                        |
| CLR         | Clear                                           |
| CMP         | Compare                                         |
| CMPA        | Compare Address                                 |
| CMPI        | Compare Immediate                               |
| СМРМ        | Compare Memory to Memory                        |
| CMP2        | Compare Register Against Upper and Lower Bounds |
| срВсс       | Branch on Coprocessor Condition                 |
| cpDBcc      | Test Coprocessor Condition Decrement and Branch |
| cpGEN       | Coprocessor General Function                    |
| cpRESTORE   | Coprocessor Restore Function                    |

Table A-2. M68000 Family Instruction Set (Continued)

| Mnemonic       | Description                                                             |
|----------------|-------------------------------------------------------------------------|
| cpSAVE         | Coprocessor Save Function                                               |
| cpScc          | Set on Coprocessor Condition                                            |
| cpTRAPcc       | Trap on Coprocessor Condition                                           |
| CPUSH          | Push then Invalidate Cache Entries                                      |
| DBcc           | Test Condition, Decrement and Branch                                    |
| DIVS, DIVSL    | Signed Divide                                                           |
| DIVU, DIVUL    | Unsigned Divide                                                         |
| EOR            | Logical Exclusive-OR                                                    |
| EORI           | Logical Exclusive-OR Immediate                                          |
| EORI to CCR    | Exclusive-OR Immediate to Condition Code Register                       |
| EORI to SR     | Exclusive-OR Immediate to Status Register                               |
| EXG            | Exchange Registers                                                      |
| EXT, EXTB      | Sign Extend                                                             |
| FABS           | Floating-Point Absolute Value                                           |
| FSFABS, FDFABS | Floating-Point Absolute Value (Single/Double Precision)                 |
| FACOS          | Floating-Point Arc Cosine                                               |
| FADD           | Floating-Point Add                                                      |
| FSADD, FDADD   | Floating-Point Add (Single/Double Precision)                            |
| FASIN          | Floating-Point Arc Sine                                                 |
| FATAN          | Floating-Point Arc Tangent                                              |
| FATANH         | Floating-Point Hyperbolic Arc Tangent                                   |
| FBcc           | Floating-Point Branch                                                   |
| FCMP           | Floating-Point Compare                                                  |
| FCOS           | Floating-Point Cosine                                                   |
| FCOSH          | Floating-Point Hyperbolic Cosine                                        |
| FDBcc          | Floating-Point Decrement and Branch                                     |
| FDIV           | Floating-Point Divide                                                   |
| FSDIV, FDDIV   | Floating-Point Divide   Floating-Point Divide (Single/Double Precision) |
| FETOX          | Floating-Point ex                                                       |
| FETOXM1        | Floating-Point ex Floating-Point ex - 1                                 |
|                | Floating-Point ex - 1 Floating-Point Get Exponent                       |
| FGETEXP        |                                                                         |
| FGETMAN        | Floating-Point Get Mantissa                                             |
| FINT           | Floating-Point Integer Part                                             |
| FINTRZ         | Floating-Point Integer Part, Round-to-Zero                              |
| FLOG10         | Floating-Point Log10                                                    |
| FLOG2          | Floating-Point Log2                                                     |
| FLOGN          | Floating-Point Loge                                                     |
| FLOGNP1        | Floating-Point Loge (x + 1)                                             |
| FMOD           | Floating-Point Modulo Remainder                                         |
| FMOVE          | Move Floating-Point Register                                            |
| FSMOVE,FDMOVE  | Move Floating-Point Register (Single/Double Precision)                  |
| FMOVECR        | Move Constant ROM                                                       |
| FMOVEM         | Move Multiple Floating-Point Registers                                  |
| FMUL           | Floating-Point Multiply                                                 |
| FSMUL,FDMUL    | Floating-Point Multiply (Single/Double Precision)                       |
| FNEG           | Floating-Point Negate                                                   |
| FSNEG,FDNEG    | Floating-Point Negate (Single/Double Precision)                         |
| FNOP           | Floating-Point No Operation                                             |

Table A-2. M68000 Family Instruction Set (Continued)

| Mnemonic      | Description                                          |
|---------------|------------------------------------------------------|
| FREM          | IEEE Remainder                                       |
| FRESTORE      | Restore Floating-Point Internal State                |
| FSAVE         | Save Floating-Point Internal State                   |
| FSCALE        | Floating-Point Scale Exponent                        |
| FScc          | Floating-Point Set According to Condition            |
| FSGLDIV       | Single-Precision Divide                              |
| FSGLMUL       | Single-Precision Multiply                            |
| FSIN          | Sine                                                 |
| FSINCOS       | Simultaneous Sine and Cosine                         |
| FSINH         | Hyperbolic Sine                                      |
| FSQRT         | Floating-Point Square Root                           |
| FSSQRT,FDSQRT | Floating-Point Square Root (Single/Double Precision) |
| FSUB          |                                                      |
|               | Floating-Point Subtract (Single/Pouble Presision)    |
| FSSUB,FDSUB   | Floating-Point Subtract (Single/Double Precision)    |
| FTAN          | Tangent                                              |
| FTANH         | Hyperbolic Tangent                                   |
| FTENTOX       | Floating-Point 10x                                   |
| FTRAPcc       | Floating-Point Trap On Condition                     |
| FTST          | Floating-Point Test                                  |
| FTWOTOX       | Floating-Point 2x                                    |
| ILLEGAL       | Take Illegal Instruction Trap                        |
| JMP           | Jump                                                 |
| JSR           | Jump to Subroutine                                   |
| LEA           | Load Effective Address                               |
| LINK          | Link and Allocate                                    |
| LPSTOP        | Low-Power Stop                                       |
| LSL, LSR      | Logical Shift Left and Right                         |
| MOVE          | Move                                                 |
| MOVEA         | Move Address                                         |
| MOVE from CCR | Move from Condition Code Register                    |
| MOVE from SR  | Move from Status Register                            |
| MOVE to CCR   | Move to Condition Code Register                      |
| MOVE to SR    | Move to Status Register                              |
| MOVE USP      | Move User Stack Pointer                              |
| MOVE16        | 16-Byte Block Move                                   |
| MOVEC         | Move Control Register                                |
| MOVEM         | Move Multiple Registers                              |
| MOVEP         | Move Peripheral                                      |
| MOVEQ         | Move Quick                                           |
| MOVES         | Move Alternate Address Space                         |
| MULS          | Signed Multiply                                      |
| MULU          | Unsigned Multiply                                    |
| NBCD          | Negate Decimal with Extend                           |
| NEG           | Negate Decimal with Extend                           |
| NEGX          | Negate with Extend                                   |
| NOP           |                                                      |
|               | No Operation                                         |
| NOT           | Logical Complement                                   |

Table A-2. M68000 Family Instruction Set (Concluded)

| Mnemonic    | Description                                       |
|-------------|---------------------------------------------------|
| OR          | Logical Inclusive-OR                              |
| ORI         | Logical Inclusive-OR Immediate                    |
| ORI to CCR  | Inclusive-OR Immediate to Condition Code Register |
| ORI to SR   | Inclusive-OR Immediate to Status Register         |
| PACK        | Pack BCD                                          |
| PBcc        | Branch on PMMU Condition                          |
| PDBcc       | Test, Decrement, and Branch on PMMU Condition     |
| PEA         | Push Effective Address                            |
| PFLUSH      | Flush Entry(ies) in the ATCs                      |
| PFLUSHA     | Flush Entry(ies) in the ATCs                      |
| PFLUSHR     | Flush Entry(ies) in the ATCs and RPT Entries      |
| PFLUSHS     | Flush Entry(ies) in the ATCs                      |
| PLOAD       | Load an Entry into the ATC                        |
| PMOVE       | Move PMMU Register                                |
| PRESTORE    | PMMU Restore Function                             |
| PSAVE       | PMMU Save Function                                |
| PScc        | Set on PMMU Condition                             |
| PTEST       | Test a Logical Address                            |
| PTRAPcc     | Trap on PMMU Condition                            |
| PVALID      | Validate a Pointer                                |
| RESET       | Reset External Devices                            |
| ROL, ROR    | Rotate Left and Right                             |
| ROXL, ROXR  | Rotate with Extend Left and Right                 |
| RTD         | Return and Deallocate                             |
| RTE         | Return from Exception                             |
| RTM         | Return from Module                                |
| RTR         | Return and Restore                                |
| RTS         | Return from Subroutine                            |
| SBCD        | Subtract Decimal with Extend                      |
| Scc         | Set Conditionally                                 |
| STOP        | Stop                                              |
| SUB         | Subtract                                          |
| SUBA        | Subtract Address                                  |
| SUBI        | Subtract Immediate                                |
| SUBQ        | Subtract Quick                                    |
| SUBX        | Subtract with Extend                              |
| SWAP        | Swap Register Words                               |
| TAS         | Test Operand and Set                              |
| TBLS, TBLSN | Signed Table Lookup with Interpolate              |
| TBLU, TBLUN | Unsigned Table Lookup with Interpolate            |
| TRAP        | Trap                                              |
| TRAPcc      | Trap Conditionally                                |
| TRAPV       | Trap on Overflow                                  |
| TST         | Test Operand                                      |
| UNLK        | Unlink                                            |
| UNPK        | Unpack BCD                                        |
| OIVI IX     | Onpack DOD                                        |

## A.1 MC68000, MC68008, MC68010 PROCESSORS

The following paragraphs provide information on the MC68000, MC68008, and MC68010 instruction set and addressing modes.

## A.1.1 M68000, MC68008, and MC68010 Instruction Set

Table A-3 lists the instructions used with the MC68000 and MC68008 processors, and Table A-4 lists the instructions used with MC68010.

Table A-3. MC68000 and MC68008 Instruction Set

| Mnemonic    | Description                                       |
|-------------|---------------------------------------------------|
| ABCD        | Add Decimal with Extend                           |
| ADD         | Add                                               |
| ADDA        | Add Address                                       |
| ADDI        | Add Immediate                                     |
| ADDQ        | Add Quick                                         |
| ADDX        | Add with Extend                                   |
| AND         | Logical AND                                       |
| ANDI        | Logical AND Immediate                             |
| ANDI to CCR | AND Immediate to Condition Code Register          |
| ANDI to SR  | AND Immediate to Status Register                  |
| ASL, ASR    | Arithmetic Shift Left and Right                   |
| Bcc         | Branch Conditionally                              |
| BCHG        | Test Bit and Change                               |
| BCLR        | Test Bit and Clear                                |
| BRA         | Branch                                            |
| BSET        | Test Bit and Set                                  |
| BSR         | Branch to Subroutine                              |
| BTST        | Test Bit                                          |
| CHK         | Check Register Against Bound                      |
| CLR         | Clear                                             |
| CMP         | Compare                                           |
| CMPA        | Compare Address                                   |
| CMPI        | Compare Immediate                                 |
| СМРМ        | Compare Memory to Memory                          |
| DBcc        | Test Condition, Decrement, and Branch             |
| DIVS        | Signed Divide                                     |
| DIVU        | Unsigned Divide                                   |
| EOR         | Logical Exclusive-OR                              |
| EORI        | Logical Exclusive-OR Immediate                    |
| EORI to CCR | Exclusive-OR Immediate to Condition Code Register |
| EORI to SR  | Exclusive-OR Immediate to Status Register         |
| EXG         | Exchange Registers                                |
| EXT         | Sign Extend                                       |
| ILLEGAL     | Take Illegal Instruction Trap                     |
| JMP         | Jump                                              |
| JSR         | Jump to Subroutine                                |

Table A-3. MC68000 and MC68008 Instruction Set (Continued)

| Mnemonic     | Description                                       |
|--------------|---------------------------------------------------|
| LEA          | Load Effective Address                            |
| LINK         | Link and Allocate                                 |
| LSL, LSR     | Logical Shift Left and Right                      |
| MOVE         | Move                                              |
| MOVEA        | Move Address                                      |
| MOVE to CCR  | Move to Condition Code Register                   |
| MOVE from SR | Move from Status Register                         |
| MOVE to SR   | Move to Status Register                           |
| MOVE USP     | Move User Stack Pointer                           |
| MOVEM        | Move Multiple Registers                           |
| MOVEP        | Move Peripheral                                   |
| MOVEQ        | Move Quick                                        |
| MULS         | Signed Multiply                                   |
| MULU         | Unsigned Multiply                                 |
| NBCD         | Negate Decimal with Extend                        |
| NEG          | Negate                                            |
| NEGX         | Negate with Extend                                |
| NOP          | No Operation                                      |
| NOT          | Logical Complement                                |
| OR           | Logical Inclusive-OR                              |
| ORI          | Logical Inclusive-OR Immediate                    |
| ORI to CCR   | Inclusive-OR Immediate to Condition Code Register |
| ORI to SR    | Inclusive-OR Immediate to Status Register         |
| PEA          | Push Effective Address                            |
| RESET        | Reset External Devices                            |
| ROL, ROR     | Rotate Left and Right                             |
| ROXL, ROXR   | Rotate with Extend Left and Right                 |
| RTE          | Return from Exception                             |
| RTR          | Return and Restore                                |
| RTS          | Return from Subroutine                            |
| SBCD         | Subtract Decimal with Extend                      |
| Scc          | Set Conditionally                                 |
| STOP         | Stop                                              |
| SUB          | Subtract                                          |
| SUBA         | Subtract Address                                  |
| SUBI         | Subtract Immediate                                |
| SUBQ         | Subtract Quick                                    |
| SUBX         | Subtract with Extend                              |
| SWAP         | Swap Register Words                               |
| TAS          | Test Operand and Set                              |
| TRAP         | Trap                                              |
| TRAPV        | Trap on Overflow                                  |
| TST          | Test Operand                                      |
| UNLK         | Unlink                                            |

Table A-4. MC68010 Instruction Set

| Mnemonic    | Description                                       |
|-------------|---------------------------------------------------|
| ABCD        | Add Decimal with Extend                           |
| ADD         | Add                                               |
| ADDA        | Add Address                                       |
| ADDI        | Add Immediate                                     |
| ADDQ        | Add Quick                                         |
| ADDX        | Add with Extend                                   |
| AND         | Logical AND                                       |
| ANDI        | Logical AND Immediate                             |
| ANDI to CCR | AND Immediate to Condition Code Register          |
| ANDI to SR  | AND Immediate to Status Register                  |
| ASL, ASR    | Arithmetic Shift Left and Right                   |
| Bcc         | Branch Conditionally                              |
| BCHG        | Test Bit and Change                               |
| BCLR        | Test Bit and Clear                                |
| BKPT        | Breakpoint                                        |
| BRA         | Branch                                            |
| BSET        | Test Bit and Set                                  |
| BSR         | Branch to Subroutine                              |
| BTST        | Test Bit                                          |
| CHK         | Check Register Against Bound                      |
| CLR         | Clear                                             |
| CMP         | Compare                                           |
| CMPA        | Compare Address                                   |
| CMPI        | Compare Immediate                                 |
| СМРМ        | Compare Memory to Memory                          |
| DBcc        | Test Condition, Decrement and Branch              |
| DIVS        | Signed Divide                                     |
| DIVU        | Unsigned Divide                                   |
| EOR         | Logical Exclusive-OR                              |
| EORI        | Logical Exclusive-OR Immediate                    |
| EORI to CCR | Exclusive-OR Immediate to Condition Code Register |
| EORI to SR  | Exclusive-OR Immediate to Status Register         |
| EXG         | Exchange Registers                                |
| EXT         | Sign Extend                                       |
| ILLEGAL     | Take Illegal Instruction Trap                     |
| JMP         | Jump                                              |
| JSR         | Jump to Subroutine                                |

Table A-4. MC68010 Instruction Set (Continued)

| Mnemonic      | Description                                       |
|---------------|---------------------------------------------------|
| LEA           | Load Effective Address                            |
| LINK          | Link and Allocate                                 |
| LSL, LSR      | Logical Shift Left and Right                      |
| MOVE          | Move                                              |
| MOVEA         | Move Address                                      |
| MOVE from CCR | Move from Condition Code Register                 |
| MOVE from SR  | Move from Status Register                         |
| MOVE to CCR   | Move to Condition Code Register                   |
| MOVE to SR    | Move to Status Register                           |
| MOVE USP      | Move User Stack Pointer                           |
| MOVEC         | Move Control Register                             |
| MOVEM         | Move Multiple Registers                           |
| MOVEP         | Move Peripheral                                   |
| MOVEQ         | Move Quick                                        |
| MOVES         | Move Address Space                                |
| MULS          | Signed Multiply                                   |
| MULU          | Unsigned Multiply                                 |
| NBCD          | Negate Decimal with Extend                        |
| NEG           | Negate                                            |
| NEGX          | Negate with Extend                                |
| NOP           | No Operation                                      |
| NOT           | Logical Complement                                |
| OR            | Logical Inclusive-OR                              |
| ORI           | Logical Inclusive-OR Immediate                    |
| ORI to CCR    | Inclusive-OR Immediate to Condition Code Register |
| ORI to SR     | Inclusive-OR Immediate to Status Register         |
| PEA           | Push Effective Address                            |
| RESET         | Reset External Devices                            |
| ROL, ROR      | Rotate Left and Right                             |
| ROXL, ROXR    | Rotate with Extend Left and Right                 |
| RTD           | Return and Deallocate                             |
| RTE           | Return from Exception                             |
| RTR           | Return and Restore                                |
| RTS           | Return from Subroutine                            |
| SBCD          | Subtract Decimal with Extend                      |
| Scc           | Set Conditionally                                 |
| STOP          | Stop                                              |
| SUB           | Subtract                                          |
| SUBA          | Subtract Address                                  |
| SUBI          | Subtract Immediate                                |
| SUBQ          | Subtract Quick                                    |
| SUBX          | Subtract Quick Subtract with Extend               |
| SWAP          | Swap Register Words                               |
| TAS           | • •                                               |
|               | Test Operand and Set                              |
| TRAP          | Trap on Overflow                                  |
| TRAPV         | Trap on Overflow                                  |
| TST           | Test Operand                                      |
| UNLK          | Unlink                                            |

# A.1.2 MC68000, MC68008, and MC68010 Addressing Modes

The MC68000, MC68008, and MC68010 support 14 addressing modes as shown in Table A-5.

Table A-5. MC68000, MC68008, and MC68010 Data Addressing Modes

| Mode                                                                                                                                                                              | Generation                                                                                                                                                                     |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Register Direct Addressing Data Register Direct Address Register Direct                                                                                                           | <ea> = Dn<br/><ea> = An</ea></ea>                                                                                                                                              |
| Absolute Data Addressing Absolute Short Absolute Long                                                                                                                             | <ea> = (Next Word)<br/><ea> = (Next Two Words)</ea></ea>                                                                                                                       |
| Program Counter Relative Addressing Relative with Offset Relative with Index and Offset                                                                                           | $ = (PC) + d_{16}$<br>$ = (PC) + d_{8}$                                                                                                                                        |
| Register Indirect Addressing Register Indirect Postincrement Register Indirect Predecrement Register Indirect Register Indirect with Offset Indexed Register Indirect with Offset | <ea> = (An)<br/><ea> = (An), An - An + N<br/>An - An - N, <ea> = (An)<br/><math><ea> = (An) + d_{16}</ea></math><br/><math><ea> = (An) + (Xn) + d_8</ea></math></ea></ea></ea> |
| Immediate Data Addressing Immediate Quick Immediate                                                                                                                               | DATA = Next Word(s) Inherent Data                                                                                                                                              |
| Implied Addressing Implied Register                                                                                                                                               | <ea> = SR, USP, SSP, PC, VBR, SFC, DFC</ea>                                                                                                                                    |

N=1 for byte, 2 for word, and 4 for long word. If An is the stack pointer and the operand size is byte, N=2 to keep the stack pointer on a word boundary.

## A.2 MC68020 PROCESSORS

The following paragraphs provide information on the MC68020 instruction set and addressing modes.

## A.2.1 MC68020 Instruction Set

Table A-6 lists the instructions used with the MC68020 processors.

Table A-6. MC68020 Instruction Set Summary

| Mnemonic    | Description                                     |
|-------------|-------------------------------------------------|
| ABCD        | Add Decimal with Extend                         |
| ADD         | Add                                             |
| ADDA        | Add Address                                     |
| ADDI        | Add Immediate                                   |
| ADDQ        | Add Quick                                       |
| ADDX        | Add with Extend                                 |
| AND         | Logical AND                                     |
| ANDI        | Logical AND Immediate                           |
| ANDI to CCR | AND Immediate to Condition Code Register        |
| ANDI to SR  | AND Immediate to Status Register                |
| ASL, ASR    | Arithmetic Shift Left and Right                 |
| Bcc         | Branch Conditionally                            |
| BCHG        | Test Bit and Change                             |
| BCLR        | Test Bit and Clear                              |
| BFCHG       | Test Bit Field and Change                       |
| BFCLR       | Test Bit Field and Clear                        |
| BFEXTS      | Signed Bit Field Extract                        |
| BFEXTU      | Unsigned Bit Field Extract                      |
| BFFFO       | Bit Field Find First One                        |
| BFINS       | Bit Field Insert                                |
| BFSET       | Test Bit Field and Set                          |
| BFTST       | Test Bit Field                                  |
| BKPT        | Breakpoint                                      |
| BRA         | Branch                                          |
| BSET        | Test Bit and Set                                |
| BSR         | Branch to Subroutine                            |
| BTST        | Test Bit                                        |
| CALLM       | CALL Module                                     |
| CAS         | Compare and Swap Operands                       |
| CAS2        | Compare and Swap Dual Operands                  |
| CHK         | Check Register Against Bound                    |
| CHK2        | Check Register Against Upper and Lower Bounds   |
| CLR         | Clear                                           |
| CMP         | Compare                                         |
| CMP2        | Compare Register Against Upper and Lower Bounds |
| CMPA        | Compare Address                                 |
| CMPI        | Compare Immediate                               |

Table A-6. MC68020 Instruction Set Summary (Continued)

| Mnemonic      | Description                                       |
|---------------|---------------------------------------------------|
| СМРМ          | Compare Memory to Memory                          |
| срВсс         | Branch to Coprocessor Condition                   |
| cpDBcc        | Test Coprocessor Condition, Decrement and Branch  |
| cpGEN         | Coprocessor General Function                      |
| cpRESTORE     | Coprocessor Restore Function                      |
| cpSAVE        | Coprocessor Save Function                         |
| cpScc         | Set on Coprocessor Condition                      |
| cpTRACPcc     | Trap on Coprocessor Condition                     |
| DBcc          | Test Condition, Decrement, and Branch             |
| DIVS, DIVSL   | Signed Divide                                     |
| DIVU, DIVUL   | Unsigned Divide                                   |
| EOR           | Logical Exclusive-OR                              |
| EORI          | Logical Exclusive-OR Immediate                    |
| EORI to CCR   | Exclusive-OR Immediate to Condition Code Register |
| EORI to SR    | Exclusive-OR Immediate to Status Register         |
| EXG           | Exchange Registers                                |
| EXT, EXTB     | Sign Extend                                       |
| ILLEGAL       | Take Illegal Instruction Trap                     |
| JMP           | Jump                                              |
| JSR           | Jump to Subroutine                                |
| LEA           | Load Effective Address                            |
| LINK          | Link and Allocate                                 |
| LSL, LSR      | Logical Shift Left and Right                      |
| MOVE          | Move                                              |
| MOVEA         | Move Address                                      |
| MOVE from CCR | Move from Condition Code Register                 |
| MOVE from SR  | Move from Status Register                         |
| MOVE to CCR   | Move to Condition Code Register                   |
| MOVE to SR    | Move to Status Register                           |
| MOVE USP      | Move User Stack Pointer                           |
| MOVEC         | Move Control Register                             |
| MOVEM         | Move Multiple Registers                           |
| MOVEP         | Move Peripheral                                   |
| MOVEQ         | Move Quick                                        |
| MOVES         | Move Alternate Address Space                      |
| MULS          | Signed Multiply                                   |
| MULU          | Unsigned Multiply                                 |
| NBCD          | Negate Decimal with Extend                        |
| NEG           | Negate                                            |
| NEGX          | Negate with Extend                                |
| NOP           | No Operation                                      |
| NOT           | Logical Complement                                |

MOTOROLA

Table A-6. MC68020 Instruction Set Summary (Concluded)

| Mnemonic   | Description                                       |
|------------|---------------------------------------------------|
| OR         | Logical Inclusive-OR                              |
| ORI        | Logical Inclusive-OR Immediate                    |
| ORI to CCR | Inclusive-OR Immediate to Condition Code Register |
| ORI to SR  | Inclusive-OR Immediate to Status Register         |
| PACK       | Pack BCD                                          |
| PEA        | Push Effective Address                            |
| RESET      | Reset External Devices                            |
| ROL, ROR   | Rotate Left and Right                             |
| ROXL, ROXR | Rotate with Extend Left and Right                 |
| RTD        | Return and Deallocate                             |
| RTE        | Return from Exception                             |
| RTM        | Return from Module                                |
| RTR        | Return and Restore                                |
| RTS        | Return from Subroutine                            |
| SBCD       | Subtract Decimal with Extend                      |
| Scc        | Set Conditionally                                 |
| STOP       | Stop                                              |
| SUB        | Subtract                                          |
| SUBA       | Subtract Address                                  |
| SUBI       | Subtract Immediate                                |
| SUBQ       | Subtract Quick                                    |
| SUBX       | Subtract with Extend                              |
| SWAP       | Swap Register Words                               |
| TAS        | Test Operand and Set                              |
| TRAP       | Trap                                              |
| TRAPcc     | Trap Conditionally                                |
| TRAPV      | Trap on Overflow                                  |
| TST        | Test Operand                                      |
| UNLK       | Unlink                                            |
| UNPK       | Unpack BCD                                        |

# A.2.2 MC68020 Addressing Modes

The MC68020 supports 18 addressing modes as shown in Table A-7.

Table A-7. MC68020 Data Addressing Modes

| Addressing Modes                                                                                                                                                                 | Syntax                                          |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|--|
| Register Direct Address Register Direct                                                                                                                                          | Dn                                              |  |
| Address Register Direct                                                                                                                                                          | An                                              |  |
| Register Indirect Address Register Indirect Address Register Indirect with Postincrement Address Register Indirect with Predecrement Address Register Indirect with Displacement | (An)<br>(An)+<br>-(An)<br>(d <sub>16</sub> ,An) |  |
| Register Indirect with Index Address Register Indirect with Index (8-Bit Displacement) Address Register Indirect with Index (Base Displacement)                                  | (d <sub>8</sub> ,An,Xn)<br>(bd,An,Xn)           |  |
| Memory Indirect Memory Indirect Postindexed Memory Indirect Preindexed                                                                                                           | ([bd,An],Xn,od)<br>([bd,An,Xn],od)              |  |
| Program Counter Indirect with Displacement                                                                                                                                       | (d <sub>16</sub> ,PC)                           |  |
| Program Counter Indirect with Index PC Indirect with Index (8-Bit Displacement) PC Indirect with Index (Base Displacement)                                                       | (d <sub>8</sub> ,PC,Xn)<br>(bd,PC,Xn)           |  |
| Program Counter Memory Indirect PC Memory Indirect Postindexed PC Memory Indirect Preindexed                                                                                     | ([bd,PC],Xn,od)<br>([bd,PC,Xn],od)              |  |
| Absolute Absolute Short Absolute Long                                                                                                                                            | (xxx).W<br>(xxx).L                              |  |
| Immediate                                                                                                                                                                        | # <data></data>                                 |  |

**MOTOROLA** 

### A.3 MC68030 PROCESSORS

The following paragraphs provide information on the MC68030 instruction set and addressing modes.

### A.3.1 MC68030 Instruction Set

Table A-8 lists the instructions used with the MC68030 processors.

Table A-8. MC68030 Instruction Set Summary

| Mnemonic    | Description                                   |
|-------------|-----------------------------------------------|
| ABCD        | Add Decimal with Extend                       |
| ADD         | Add                                           |
| ADDA        | Add Address                                   |
| ADDI        | Add Immediate                                 |
| ADDQ        | Add Quick                                     |
| ADDX        | Add with Extend                               |
| AND         | Logical AND                                   |
| ANDI        | Logical AND Immediate                         |
| ANDI to CCR | AND Immediate to Condition Code Register      |
| ANDI to SR  | AND Immediate to Status Register              |
| ASL, ASR    | Arithmetic Shift Left and Right               |
| Bcc         | Branch Conditionally                          |
| BCHG        | Test Bit and Change                           |
| BCLR        | Test Bit and Clear                            |
| BFCHG       | Test Bit Field and Change                     |
| BFCLR       | Test Bit Field and Clear                      |
| BFEXTS      | Signed Bit Field Extract                      |
| BFEXTU      | Unsigned Bit Field Extract                    |
| BFFFO       | Bit Field Find First One                      |
| BFINS       | Bit Field Insert                              |
| BFSET       | Test Bit Field and Set                        |
| BFTST       | Test Bit Field                                |
| BKPT        | Breakpoint                                    |
| BRA         | Branch                                        |
| BSET        | Test Bit and Set                              |
| BSR         | Branch to Subroutine                          |
| BTST        | Test Bit                                      |
| CAS         | Compare and Swap Operands                     |
| CAS2        | Compare and Swap Dual Operands                |
| CHK         | Check Register Against Bound                  |
| CHK2        | Check Register Against Upper and Lower Bounds |
| CLR         | Clear                                         |
| CMP         | Compare                                       |
| CMPA        | Compare Address                               |
| CMPI        | Compare Immediate                             |
| СМРМ        | Compare Memory to Memory                      |

Table A-8. MC68030 Instruction Set Summary (Continued)

| Mnemonic      | Description                                       |
|---------------|---------------------------------------------------|
| CMP2          | Compare Register Against Upper and Lower Bounds   |
| срВсс         | Branch on Coprocessor Condition                   |
| cpDBcc        | Test Coprocessor Condition, Decrement and Branch  |
| cpGEN         | Coprocessor General Function                      |
| cpRESTORE     | Coprocessor Restore Function                      |
| cpSAVE        | Coprocessor Save Function                         |
| cpScc         | Set on Coprocessor Condition                      |
| cpTRAPcc      | Trap on Coprocessor Condition                     |
| DBcc          | Test Condition, Decrement and Branch              |
| DIVS, DIVSL   | Signed Divide                                     |
| DIVU, DIVUL   | Unsigned Divide                                   |
| EOR           | Logical Exclusive-OR                              |
| EORI          | Logical Exclusive-OR Immediate                    |
| EORI to CCR   | Exclusive-OR Immediate to Condition Code Register |
| EORI to SR    | Exclusive-OR Immediate to Status Register         |
| EXG           | Exchange Registers                                |
| EXT, EXTB     | Sign Extend                                       |
| ILLEGAL       | Take Illegal Instruction Trap                     |
| JMP           | Jump                                              |
| JSR           | Jump to Subroutine                                |
| LEA           | Load Effective Address                            |
| LINK          | Link and Allocate                                 |
| LSL, LSR      | Logical Shift Left and Right                      |
| MOVE          | Move                                              |
| MOVEA         | Move Address                                      |
| MOVE from CCR | Move from Condition Code Register                 |
| MOVE to CCR   | Move to Condition Code Register                   |
| MOVE from SR  | Move from Status Register                         |
| MOVE to SR    | Move to Status Register                           |
| MOVE USP      | Move User Stack Pointer                           |
| MOVEC         | Move Control Register                             |
| MOVEM         | Move Multiple Registers                           |
| MOVEP         | Move Peripheral                                   |
| MOVEQ         | Move Quick                                        |
| MOVES         | Move Alternate Address Space                      |
| MULS          | Signed Multiply                                   |
| MULU          | Unsigned Multiply                                 |
| NBCD          | Negate Decimal with Extend                        |
| NEG           | Negate                                            |
| NEGX          | Negate with Extend                                |
| NOP           | No Operation                                      |
| NOT           | Logical Complement                                |

Table A-8. MC68030 Instruction Set Summary (Concluded)

| Mnemonic   | Description                                       |
|------------|---------------------------------------------------|
| NBCD       | Negate Decimal with Extend                        |
| NEG        | Negate                                            |
| NEGX       | Negate with Extend                                |
| NOP        | No Operation                                      |
| NOT        | Logical Complement                                |
| OR         | Logical Inclusive-OR                              |
| ORI        | Logical Inclusive-OR Immediate                    |
| ORI to CCR | Inclusive-OR Immediate to Condition Code Register |
| ORI to SR  | Inclusive-OR Immediate to Status Register         |
| PACK       | Pack BCD                                          |
| PEA        | Push Effective Address                            |
| PFLUSH*    | Invalidate Entries in the ATC                     |
| PFLUSHA*   | Invalidate all Entries in the ATC                 |
| PLOAD*     | Load an Entry into the ATC                        |
| PMOVE      | Move PMMU Register                                |
| PTEST      | Get Information about Logical Address             |
| RESET      | Reset External Devices                            |
| ROL, ROR   | Rotate Left and Right                             |
| ROXL, ROXR | Rotate with Extend Left and Right                 |
| RTD        | Return and Deallocate                             |
| RTE        | Return from Exception                             |
| RTR        | Return and Restore                                |
| RTS        | Return from Subroutine                            |
| SBCD       | Subtract Decimal with Extend                      |
| Scc        | Set Conditionally                                 |
| STOP       | Stop                                              |
| SUB        | Subtract                                          |
| SUBA       | Subtract Address                                  |
| SUBI       | Subtract Immediate                                |
| SUBQ       | Subtract Quick                                    |
| SUBX       | Subtract with Extend                              |
| SWAP       | Swap Register Words                               |
| TAS        | Test Operand and Set                              |
| TRAP       | Trap                                              |
| TRAPcc     | Trap Conditionally                                |
| TRAPV      | Trap on Overflow                                  |
| TST        | Test Operand                                      |
| UNLK       | Unlink                                            |
| UNPK       | Unpack BCD                                        |

<sup>\*</sup>Not applicable to the MC68EC030

# A.3.2 MC68030 Addressing Modes

The MC68030 supports 18 addressing modes as shown in Table A-9.

Table A-9. MC68030 Data Addressing Modes

| Addressing Modes                                                                                                                                                                 | Syntax                                          |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|
| Register Direct Data Register Direct Address Register Direct                                                                                                                     | Dn<br>An                                        |
| Register Indirect Address Register Indirect Address Register Indirect with Postincrement Address Register Indirect with Predecrement Address Register Indirect with Displacement | (An)<br>(An)+<br>–(An)<br>(d <sub>16</sub> ,An) |
| Register Indirect with Index Address Register Indirect with Index (8-Bit Displacement) Address Register Indirect with Index (Base Displacement)                                  | (d <sub>8</sub> ,An,Xn)<br>(bd,An,Xn)           |
| Memory Indirect Memory Indirect Postindexed Memory Indirect Preindexed                                                                                                           | ([bd,An],Xn,od)<br>([bd,An,Xn],od)              |
| Program Counter Indirect with Displacement                                                                                                                                       | (d <sub>16</sub> ,PC)                           |
| Program Counter Indirect with Index PC Indirect with Index (8-Bit Displacement) PC Indirect with Index (Base Displacement)                                                       | (d <sub>8</sub> ,PC,Xn)<br>(bd,PC,Xn)           |
| Program Counter Memory Indirect PC Memory Indirect Postindexed PC Memory Indirect Preindexed                                                                                     | ([bd,PC],Xn,od)<br>([bd,PC,Xn],od)              |
| Absolute Absolute Short Absolute Long                                                                                                                                            | (xxx).W<br>(xxx).L                              |
| Immediate                                                                                                                                                                        | # <data></data>                                 |

### A.4 MC68040 PROCESSORS

The following paragraphs provide information on the MC68040 instruction set and addressing modes.

### A.4.1 MC68040 Instruction Set

Table A-10 lists the instructions used with the MC68040 processor.

Table A-10. MC68040 Instruction Set

| Mnemonic    | Description                                   |
|-------------|-----------------------------------------------|
| ABCD        | Add Decimal with Extend                       |
| ADD         | Add                                           |
| ADDA        | Add Address                                   |
| ADDI        | Add Immediate                                 |
| ADDQ        | Add Quick                                     |
| ADDX        | Add with Extend                               |
| AND         | Logical AND                                   |
| ANDI        | Logical AND Immediate                         |
| ANDI to CCR | AND Immediate to Condition Code Register      |
| ANDI to SR  | AND Immediate to Status Register              |
| ASL, ASR    | Arithmetic Shift Left and Right               |
| Bcc         | Branch Conditionally                          |
| BCHG        | Test Bit and Change                           |
| BCLR        | Test Bit and Clear                            |
| BFCHG       | Test Bit Field and Change                     |
| BFCLR       | Test Bit Field and Clear                      |
| BFEXTS      | Signed Bit Field Extract                      |
| BFEXTU      | Unsigned Bit Field Extract                    |
| BFFFO       | Bit Field Find First One                      |
| BFINS       | Bit Field Insert                              |
| BFSET       | Test Bit Field and Set                        |
| BFTST       | Test Bit Field                                |
| BKPT        | Breakpoint                                    |
| BRA         | Branch                                        |
| BSET        | Test Bit and Set                              |
| BSR         | Branch to Subroutine                          |
| BTST        | Test Bit                                      |
| CAS         | Compare and Swap Operands                     |
| CAS2        | Compare and Swap Dual Operands                |
| CHK         | Check Register Against Bound                  |
| CHK2        | Check Register Against Upper and Lower Bounds |
| CINV        | Invalidate Cache Entries                      |
| CLR         | Clear                                         |
| CMP         | Compare                                       |
| СМРА        | Compare Address                               |

Table A-10. MC68040 Instruction Set (Continued)

| Mnemonic                                                                                                                                                                                                            | Description                                                                                                                                                                                                                                                                                                  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CMPI                                                                                                                                                                                                                | Compare Immediate                                                                                                                                                                                                                                                                                            |
| СМРМ                                                                                                                                                                                                                | Compare Memory to Memory                                                                                                                                                                                                                                                                                     |
| CMP2                                                                                                                                                                                                                | Compare Register Against Upper and Lower Bounds                                                                                                                                                                                                                                                              |
| CPUSH                                                                                                                                                                                                               | Push then Invalidate Cache Entries                                                                                                                                                                                                                                                                           |
| DBcc                                                                                                                                                                                                                | Test Condition, Decrement and Branch                                                                                                                                                                                                                                                                         |
| DIVS, DIVSL                                                                                                                                                                                                         | Signed Divide                                                                                                                                                                                                                                                                                                |
| DIVU, DIVUL                                                                                                                                                                                                         | Unsigned Divide                                                                                                                                                                                                                                                                                              |
| EOR                                                                                                                                                                                                                 | Logical Exclusive-OR                                                                                                                                                                                                                                                                                         |
| EORI - COR                                                                                                                                                                                                          | Logical Exclusive-OR Immediate                                                                                                                                                                                                                                                                               |
| EORI to CCR<br>EORI to SR                                                                                                                                                                                           | Exclusive-OR Immediate to Condition Code Register                                                                                                                                                                                                                                                            |
| EXG                                                                                                                                                                                                                 | Exclusive-OR Immediate to Status Register Exchange Registers                                                                                                                                                                                                                                                 |
| EXT, EXTB                                                                                                                                                                                                           | Sign Extend                                                                                                                                                                                                                                                                                                  |
| FABS <sup>1</sup>                                                                                                                                                                                                   | Floating-Point Absolute Value                                                                                                                                                                                                                                                                                |
| FSABS, FDABS <sup>1</sup>                                                                                                                                                                                           | Floating-Point Absolute Value (Single/Double Precision)                                                                                                                                                                                                                                                      |
| FACOS <sup>1,2</sup>                                                                                                                                                                                                | Floating-Point Arc Cosine                                                                                                                                                                                                                                                                                    |
| FADD <sup>1</sup>                                                                                                                                                                                                   | Floating-Point Add                                                                                                                                                                                                                                                                                           |
| FSADD, FDADD <sup>1</sup>                                                                                                                                                                                           | Floating-Point Add (Single/Double Precision)                                                                                                                                                                                                                                                                 |
| FASIN <sup>1,2</sup>                                                                                                                                                                                                | Floating-Point Arc Sine                                                                                                                                                                                                                                                                                      |
| FATAN <sup>1,2</sup>                                                                                                                                                                                                | Floating-Point Arc Tangent                                                                                                                                                                                                                                                                                   |
| FATANH <sup>1,2</sup>                                                                                                                                                                                               | Floating-Point Hyperbolic Arc Tangent                                                                                                                                                                                                                                                                        |
| FBcc <sup>1</sup>                                                                                                                                                                                                   | Floating-Point Branch                                                                                                                                                                                                                                                                                        |
| FCMP <sup>1</sup>                                                                                                                                                                                                   | Floating-Point Compare                                                                                                                                                                                                                                                                                       |
| FCOS <sup>1,2</sup>                                                                                                                                                                                                 | Floating-Point Cosine                                                                                                                                                                                                                                                                                        |
| FCOSH <sup>1,2</sup>                                                                                                                                                                                                | Floating-Point Hyperbolic Cosine                                                                                                                                                                                                                                                                             |
| FDBcc <sup>1</sup>                                                                                                                                                                                                  | Floating-Point Decrement and Branch                                                                                                                                                                                                                                                                          |
| FDIV <sup>1</sup>                                                                                                                                                                                                   | Floating-Point Divide                                                                                                                                                                                                                                                                                        |
| FSDIV, FDDIV <sup>1</sup>                                                                                                                                                                                           | Floating-Point Divide (Single/Double Precision)                                                                                                                                                                                                                                                              |
| FETOX <sup>1,2</sup>                                                                                                                                                                                                | Floating-Point e <sup>x</sup>                                                                                                                                                                                                                                                                                |
| FETOXM1 <sup>1,2</sup>                                                                                                                                                                                              | Floating-Point e <sup>x</sup> - 1                                                                                                                                                                                                                                                                            |
| FGETEXP <sup>1,2</sup>                                                                                                                                                                                              | Floating-Point Get Exponent                                                                                                                                                                                                                                                                                  |
| FGETMAN <sup>1,2</sup>                                                                                                                                                                                              | Floating-Point Get Mantissa                                                                                                                                                                                                                                                                                  |
| FINT <sup>1,2</sup>                                                                                                                                                                                                 | Floating-Point Integer Part                                                                                                                                                                                                                                                                                  |
| FINTRZ <sup>1,2</sup>                                                                                                                                                                                               | Floating-Point Integer Part, Round-to-Zero                                                                                                                                                                                                                                                                   |
| FLOG10 <sup>1,2</sup>                                                                                                                                                                                               | Floating-Point Log <sub>10</sub>                                                                                                                                                                                                                                                                             |
| FLOG2 <sup>1,2</sup>                                                                                                                                                                                                | Floating-Point Log <sub>2</sub>                                                                                                                                                                                                                                                                              |
| FLOGN <sup>1,2</sup>                                                                                                                                                                                                | Floating-Point Log <sub>e</sub>                                                                                                                                                                                                                                                                              |
| FLOGNP1 <sup>1,2</sup>                                                                                                                                                                                              | Floating-Point Log <sub>e</sub> (x + 1)                                                                                                                                                                                                                                                                      |
|                                                                                                                                                                                                                     | Floating-Point Modulo Remainder                                                                                                                                                                                                                                                                              |
| FMOVE <sup>1</sup>                                                                                                                                                                                                  | Move Floating-Point Register                                                                                                                                                                                                                                                                                 |
| FSMOVE, FDMOVE <sup>1</sup>                                                                                                                                                                                         | Move Floating-Point Register (Single/Double Precision)                                                                                                                                                                                                                                                       |
| FMOVECR <sup>1</sup>                                                                                                                                                                                                | Move Constant ROM                                                                                                                                                                                                                                                                                            |
| FMOVEM <sup>1</sup>                                                                                                                                                                                                 | Move Multiple Floating-Point Registers                                                                                                                                                                                                                                                                       |
| FMUL <sup>1</sup>                                                                                                                                                                                                   | Floating-Point Multiply                                                                                                                                                                                                                                                                                      |
| FSMUL, FDMUL <sup>1</sup>                                                                                                                                                                                           | Floating-Point Multiply (Single/Double Precision)                                                                                                                                                                                                                                                            |
| FLOG2 <sup>1,2</sup> FLOGN <sup>1,2</sup> FLOGNP1 <sup>1,2</sup> FMOD <sup>1,2</sup> FMOVE <sup>1</sup> FSMOVE, FDMOVE <sup>1</sup> FMOVECR <sup>1</sup> FMOVECR <sup>1</sup> FMOVEM <sup>1</sup> FMUL <sup>1</sup> | Floating-Point Log <sub>2</sub> Floating-Point Log <sub>e</sub> Floating-Point Log <sub>e</sub> (x + 1) Floating-Point Modulo Remainder Move Floating-Point Register Move Floating-Point Register (Single/Double Precision) Move Constant ROM Move Multiple Floating-Point Registers Floating-Point Multiply |

Table A-10. MC68040 Instruction Set (Continued)

| Mnemonic                    | Description                                          |
|-----------------------------|------------------------------------------------------|
| FNEG <sup>1</sup>           | Floating-Point Negate                                |
| FSNEG, FDNEG <sup>1</sup>   | Floating-Point Negate (Single/Double Precision)      |
| FNOP <sup>1</sup>           | Floating-Point No Operation                          |
| FREM <sup>1,2</sup>         | IEEE Remainder                                       |
| FRESTORE <sup>1</sup>       | Restore Floating-Point Internal State                |
| FSAVE <sup>1</sup>          | Save Floating-Point Internal State                   |
| FSCALE <sup>1,2</sup>       | Floating-Point Scale Exponent                        |
| FScc <sup>1</sup>           | Floating-Point Set According to Condition            |
| FSGLDIV <sup>1,2</sup>      | Single-Precision Divide                              |
|                             | Single-Precision Multiply                            |
| FSGLMUL <sup>1,2</sup>      |                                                      |
| FSIN <sup>1,2</sup>         | Sine                                                 |
| FSINCOS <sup>1,2</sup>      | Simultaneous Sine and Cosine                         |
| FSINH <sup>1,2</sup>        | Hyperbolic Sine                                      |
| FSQRT <sup>1</sup>          | Floating-Point Square Root                           |
| FSSQRT, FDSQRT <sup>1</sup> | Floating-Point Square Root (Single/Double Precision) |
| FSUB <sup>1</sup>           | Floating-Point Subtract                              |
| FSSUB, FDSUB <sup>1</sup>   | Floating-Point Subtract (Single/Double Precision)    |
| FTAN <sup>1,2</sup>         | Tangent                                              |
| FTANH <sup>1,2</sup>        | Hyperbolic Tangent                                   |
| FTENTOX <sup>1,2</sup>      | Floating-Point 10 <sup>x</sup>                       |
| FTRAPcc <sup>1,2</sup>      | Floating-Point Trap On Condition                     |
| FTST <sup>1</sup>           | Floating-Point Test                                  |
| FTWOTOX <sup>1,2</sup>      | Floating-Point 2 <sup>x</sup>                        |
| ILLEGAL                     | Take Illegal Instruction Trap                        |
| JMP                         | Jump                                                 |
| JSR                         | Jump to Subroutine                                   |
| LEA                         | Load Effective Address                               |
| LINK                        | Link and Allocate                                    |
| LSL, LSR<br>MOVE            | Logical Shift Left and Right  Move                   |
| MOVEA                       | Move Address                                         |
| MOVE from CCR               | Move from Condition Code Register                    |
| MOVE to CCR                 | Move to Condition Code Register                      |
| MOVE from SR                | Move from Status Register                            |
| MOVE to SR                  | Move to Status Register                              |
| MOVE USP                    | Move User Stack Pointer                              |
| MOVEC                       | Move Control Register                                |
| MOVEM                       | Move Multiple Registers                              |
| MOVEP                       | Move Peripheral                                      |
| MOVEQ                       | Move Quick                                           |
| MOVES                       | Move Alternate Address Space                         |
| MOVE16<br>MULS              | 16-Byte Block Move Signed Multiply                   |
| MULU                        | Unsigned Multiply                                    |
| I.V.OLO                     | onoignou multipry                                    |

Table A-10. MC68040 Instruction Set (Concluded)

| Mnemonic   | Description                                       |
|------------|---------------------------------------------------|
| NBCD       | Negate Decimal with Extend                        |
| NEG        | Negate                                            |
| NEGX       | Negate with Extend                                |
| NOP        | No Operation                                      |
| NOT        | Logical Complement                                |
| OR         | Logical Inclusive-OR                              |
| ORI        | Logical Inclusive-OR Immediate                    |
| ORI to CCR | Inclusive-OR Immediate to Condition Code Register |
| ORI to SR  | Inclusive-OR Immediate to Status Register         |
| PACK       | Pack BCD                                          |
| PEA        | Push Effective Address                            |
| PFLUSH     | Flush Entry(ies) in the ATCs                      |
| PFLUSHA    | Flush all Entry(ies) in the ATCs                  |
| PTEST      | Test a Logical Address                            |
| RESET      | Reset External Devices                            |
| ROL, ROR   | Rotate Left and Right                             |
| ROXL, ROXR | Rotate with Extend Left and Right                 |
| RTD        | Return and Deallocate                             |
| RTE        | Return from Exception                             |
| RTR        | Return and Restore                                |
| RTS        | Return from Subroutine                            |
| SBCD       | Subtract Decimal with Extend                      |
| Scc        | Set Conditionally                                 |
| STOP       | Stop                                              |
| SUB        | Subtract                                          |
| SUBA       | Subtract Address                                  |
| SUBI       | Subtract Immediate                                |
| SUBQ       | Subtract Quick                                    |
| SUBX       | Subtract with Extend                              |
| SWAP       | Swap Register Words                               |
| TAS        | Test Operand and Set                              |
| TRAP       | Trap                                              |
| TRAPcc     | Trap Conditionally                                |
| TRAPV      | Trap on Overflow                                  |
| TST        | Test Operand                                      |
| UNLK       | Unlink                                            |
| UNPK       | Unpack BCD                                        |

#### NOTES

- 1. Not applicable to the MC68EC040 and MC68LC040.
- 2. These instructions are software supported.

# A.4.2 MC68040 Addressing Modes

The MC68040 supports 18 addressing modes as shown in Table A-11.

Table A-11. MC68040 Data Addressing Modes

| Addressing Modes                                                                                                                                                                 | Syntax                                           |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|
| Register Direct Data Register Direct Address Register Direct                                                                                                                     | Dn<br>An                                         |
| Register Indirect Address Register Indirect Address Register Indirect with Postincrement Address Register Indirect with Predecrement Address Register Indirect with Displacement | (An)<br>(An) +<br>-(An)<br>(d <sub>16</sub> ,An) |
| Register Indirect with Index Address Register Indirect with Index (8-Bit Displacement) Address Register Indirect with Index (Base Displacement)                                  | (d <sub>8</sub> ,An,Xn)<br>(bd,An,Xn)            |
| Memory Indirect  Memory Indirect Postindexed  Memory Indirect Preindexed                                                                                                         | ([bd,An],Xn,od)<br>([bd,An,Xn],od)               |
| Program Counter Indirect with Displacement                                                                                                                                       | (d <sub>16</sub> ,PC)                            |
| Program Counter Indirect with Index PC Indirect with Index (8-Bit Displacement) PC Indirect with Index (Base Displacement)                                                       | (d <sub>8</sub> ,PC,Xn)<br>(bd,PC,Xn)            |
| Program Counter Memory Indirect PC Memory Indirect Postindexed PC Memory Indirect Preindexed                                                                                     | ([bd,PC],Xn,od)<br>([bd,PC,Xn],od)               |
| Absolute Absolute Short Absolute Long                                                                                                                                            | xxx.W<br>xxx.L                                   |
| Immediate                                                                                                                                                                        | # < data >                                       |

### A.5 MC68881/MC68882 COPROCESSORS

The following paragraphs provide information on the MC68881/MC68882 instruction set and addressing modes.

### A.5.1 MC68881/MC68882 Instruction Set

Table A-12 lists the instructions used with the MC68881/MC68882 coprocessors.

Table A-12. MC68881/MC68882 Instruction Set

| Mnemonic | Description                                |
|----------|--------------------------------------------|
| FABS     | Floating-Point Absolute Value              |
| FACOS    | Floating-Point Arc Cosine                  |
| FADD     | Floating-Point Add                         |
| FASIN    | Floating-Point Arc Sine                    |
| FATAN    | Floating-Point Arc Tangent                 |
| FATANH   | Floating-Point Hyperbolic Arc Tangent      |
| FBcc     | Floating-Point Branch                      |
| FCMP     | Floating-Point Compare                     |
| FCOS     | Floating-Point Cosine                      |
| FCOSH    | Floating-Point Hyperbolic Cosine           |
| FDBcc    | Floating-Point Decrement and Branch        |
| FDIV     | Floating-Point Divide                      |
| FETOX    | Floating-Point ex                          |
| FETOXM1  | Floating-Point ex - 1                      |
| FGETEXP  | Floating-Point Get Exponent                |
| FGETMAN  | Floating-Point Get Mantissa                |
| FINT     | Floating-Point Integer Part                |
| FINTRZ   | Floating-Point Integer Part, Round-to-Zero |
| FLOG10   | Floating-Point Log10                       |
| FLOG2    | Floating-Point Log2                        |
| FLOGN    | Floating-Point Loge                        |
| FLOGNP1  | Floating-Point Loge (x + 1)                |
| FMOD     | Floating-Point Modulo Remainder            |
| FMOVE    | Move Floating-Point Register               |
| FMOVECR  | Move Constant ROM                          |
| FMOVEM   | Move Multiple Floating-Point Registers     |
| FMUL     | Floating-Point Multiply                    |
| FNEG     | Floating-Point Negate                      |
| FNOP     | Floating-Point No Operation                |
| FREM     | IEEE Remainder                             |
| FRESTORE | Restore Floating-Point Internal State      |
| FSAVE    | Save Floating-Point Internal State         |
| FSCALE   | Floating-Point Scale Exponent              |
| FScc     | Floating-Point Set According to Condition  |
| FSGLDIV  | Single-Precision Divide                    |
| FSGLMUL  | Single-Precision Multiply                  |
| FSIN     | Sine                                       |
| FSINCOS  | Simultaneous Sine and Cosine               |
| FSINH    | Hyperbolic Sine                            |

Table A-12. MC68881/MC68882 Instruction Set

| Mnemonic | Description                      |
|----------|----------------------------------|
| FSQRT    | Floating-Point Square Root       |
| FSUB     | Floating-Point Subtract          |
| FTAN     | Tangent                          |
| FTANH    | Hyperbolic Tangent               |
| FTENTOX  | Floating-Point 10x               |
| FTRAPcc  | Floating-Point Trap On Condition |
| FTST     | Floating-Point Test              |
| FTWOTOX  | Floating-Point 2x                |

### A.5.2 MC68881/MC68882 Addressing Modes

The MC68881/MC68882 does not perform address calculations. When the floating-point coprocessor instructs the processor to transfer an operand via the coprocessor interface, the processor performs the addressing mode calculation requested in the instruction.

### A.6 MC68851 COPROCESSORS

The following paragraphs provide information on the MC68851 instruction set and addressing modes.

### A.6.1 MC68851 Instruction Set

Table A-13 lists the instructions used with the MC68851 coprocessor.

Table A-13. MC68851 Instruction Set

| Mnemonic | Description                                   |
|----------|-----------------------------------------------|
| PBcc     | Branch on PMMU Condition                      |
| PDBcc    | Test, Decrement, and Branch on PMMU Condition |
| PFLUSH   | Flush Entry(ies) in the ATCs                  |
| PFLUSHA  | Flush Entry(ies) in the ATCs                  |
| PFLUSHR  | Flush Entry(ies) in the ATCs and RPT Entries  |
| PFLUSHS  | Flush Entry(ies) in the ATCs                  |
| PLOAD    | Load an Entry into the ATC                    |
| PMOVE    | Move PMMU Register                            |
| PRESTORE | PMMU Restore Function                         |
| PSAVE    | PMMU Save Function                            |
| PScc     | Set on PMMU Condition                         |
| PTEST    | Test a Logical Address                        |
| PTRAPcc  | Trap on PMMU Condition                        |
| PVALID   | Validate a Pointer                            |

## A.6.2 MC68851 Addressing Modes

The MC68851 supports the same addressing modes as the MC68020 (see Table A-7).

# APPENDIX B EXCEPTION PROCESSING REFERENCE

This appendix provides a quick reference for system programmers who are already familiar with the stack frames. For more detail, please refer to the appropriate userOs manual.

### **B.1 EXCEPTION VECTOR ASSIGNMENTS FOR THE M68000 FAMILY**

Table B-1 lists all vector assignments up to and including the MC68040 and its derivatives. Many of these vector assignments are processor specific. For instance, vector 13, the coprocessor protocol violation vector, only applies to the MC68020, MC68EC020, MC68030, and MC68EC030. Refer to the appropriate user's manual to determine which exception type is applicable to a specific processor.

Table B-1. Exception Vector Assignments for the M68000 Family

| Vector<br>Number( s) | Vector<br>Offset (Hex) | Assignment                                        |
|----------------------|------------------------|---------------------------------------------------|
| 0                    | 000                    | Reset Initial Interrupt Stack Pointer             |
| 1                    | 004                    | Reset Initial Program Counter                     |
| 2                    | 800                    | Access Fault                                      |
| 3                    | 00C                    | Address Error                                     |
| 4                    | 010                    | Illegal Instruction                               |
| 5                    | 014                    | Integer Divide by Zero                            |
| 6                    | 018                    | CHK, CHK2 Instruction                             |
| 7                    | 01C                    | FTRAPcc, TRAPcc, TRAPV Instructions               |
| 8                    | 020                    | Privilege Violation                               |
| 9                    | 024                    | Trace                                             |
| 10                   | 028                    | Line 1010 Emulator (Unimplemented A- Line Opcode) |
| 11                   | 02C                    | Line 1111 Emulator (Unimplemented F-Line Opcode)  |
| 12                   | 030                    | (Unassigned, Reserved)                            |
| 13                   | 034                    | Coprocessor Protocol Violation                    |
| 14                   | 038                    | Format Error                                      |
| 15                   | 03C                    | Uninitialized Interrupt                           |
| 16–23                | 040-05C                | (Unassigned, Reserved)                            |
| 24                   | 060                    | Spurious Interrupt                                |
| 25                   | 064                    | Level 1 Interrupt Autovector                      |
| 26                   | 068                    | Level 2 Interrupt Autovector                      |
| 27                   | 06C                    | Level 3 Interrupt Autovector                      |
| 28                   | 070                    | Level 4 Interrupt Autovector                      |
| 29                   | 074                    | Level 5 Interrupt Autovector                      |
| 30                   | 078                    | Level 6 Interrupt Autovector                      |
| 31                   | 07C                    | Level 7 Interrupt Autovector                      |
| 32–47                | 080-0BC                | TRAP #0 D 15 Instruction Vectors                  |
| 48                   | 0C0                    | FP Branch or Set on Unordered Condition           |
| 49                   | 0C4                    | FP Inexact Result                                 |
| 50                   | 0C8                    | FP Divide by Zero                                 |
| 51                   | 0CC                    | FP Underflow                                      |
| 52                   | 0D0                    | FP Operand Error                                  |
| 53                   | 0D4                    | FP Overflow                                       |
| 54                   | 0D8                    | FP Signaling NAN                                  |
| 55                   | 0DC                    | FP Unimplemented Data Type (Defined for MC68040)  |
| 56                   | 0E0                    | MMU Configuration Error                           |
| 57                   | 0E4                    | MMU Illegal Operation Error                       |
| 58                   | 0E8                    | MMU Access Level Violation Error                  |
| 59–63                | 0ECD0FC                | (Unassigned, Reserved)                            |
| 64–255               | 100D3FC                | User Defined Vectors (192)                        |

### **B.2 EXCEPTION STACK FRAMES**

Figures B-1 through B-15 illustrate all exception stack frames for the M68000 family..



Figure B-1. MC68000 Group 1 and 2 Exception Stack Frame



Figure B-2. MC68000 Bus or Address Error Exception Stack Frame



Figure B-3. Four-Word Stack Frame, Format \$0



Figure B-4. Throwaway Four-Word Stack Frame, Format \$1



Figure B-5. Six-Word Stack Frame, Format \$2



Figure B-6. MC68040 Floating-Point Post-Instruction Stack Frame, Format \$3



Figure B-7. MC68EC040 and MC68LC040 Floating-Point Unimplemented Stack Frame, Format \$4



Figure B-8. MC68040 Access Error Stack Frame, Format \$7

|       | 15 |                      |     |     |                          | 0 |  |  |  |  |  |  |
|-------|----|----------------------|-----|-----|--------------------------|---|--|--|--|--|--|--|
| SP->  |    | STATUS REGISTER      |     |     |                          |   |  |  |  |  |  |  |
| +\$02 |    | PROGRAM COUNTER HIGH |     |     |                          |   |  |  |  |  |  |  |
|       |    | PROGRAM COUNTER LOW  |     |     |                          |   |  |  |  |  |  |  |
| +\$06 | 1  | 0                    | 0   | 0   | VECTOR OFFSET            |   |  |  |  |  |  |  |
| +\$08 |    |                      |     | S   | PECIAL STATUS WORD       |   |  |  |  |  |  |  |
|       |    |                      |     | F   | AULT ADDRESS HIGH        | ╝ |  |  |  |  |  |  |
| +\$0C |    |                      |     | F   | AULT ADDRESS LOW         |   |  |  |  |  |  |  |
|       |    | UNUSED, RESERVED     |     |     |                          |   |  |  |  |  |  |  |
| +\$10 |    | DATA OUTPUT BUFFER   |     |     |                          |   |  |  |  |  |  |  |
|       |    | UNUSED, RESERVED     |     |     |                          |   |  |  |  |  |  |  |
| +\$14 |    | DATA INPUT BUFFER    |     |     |                          |   |  |  |  |  |  |  |
| +\$16 |    | UNUSED, RESERVED     |     |     |                          |   |  |  |  |  |  |  |
| +\$18 |    |                      | ١N  | IST | RUCTION OUTPUT BUFFER    |   |  |  |  |  |  |  |
| \$1A  |    |                      |     |     | VERSION                  |   |  |  |  |  |  |  |
| +\$50 | L  |                      |     |     | NUMBER                   |   |  |  |  |  |  |  |
|       |    | Ī                    | NTE | RN  | AL INFORMATION, 16 WORDS |   |  |  |  |  |  |  |

NOTE: The stack pointer decrements by 29 words, although only 26 words of information actually write to memory. Motorola reserves the three additional words for future use.

Figure B-9. MC68010 Bus and Address Error Stack Frame, Format \$8



Figure B-10. MC68020 Bus and MC68030 Coprocessor Mid-Instruction Stack Frame, Format \$9

|       | 15 |                              |   |    |                        | 0 |  |  |  |  |  |  |
|-------|----|------------------------------|---|----|------------------------|---|--|--|--|--|--|--|
| SP->  |    | STATUS REGISTER              |   |    |                        |   |  |  |  |  |  |  |
| +\$02 |    | PROGRAM COUNTER —            |   |    |                        |   |  |  |  |  |  |  |
| +\$06 | 1  | 0                            | 1 | 0  | VECTOR OFFSET          |   |  |  |  |  |  |  |
| +\$08 |    |                              |   |    | INTERNAL REGISTER      |   |  |  |  |  |  |  |
| +\$0A |    |                              |   | SP | ECIAL STATUS REGISTER  |   |  |  |  |  |  |  |
| +\$0C |    | INSTRUCTION PIPE STAGE C     |   |    |                        |   |  |  |  |  |  |  |
| +\$0E |    | INSTRUCTION PIPE STATE B     |   |    |                        |   |  |  |  |  |  |  |
| +\$10 |    | — DATA CYCLE FAULT ADDRESS — |   |    |                        |   |  |  |  |  |  |  |
| +\$12 |    | DATA CYCLE FAULT ADDRESS     |   |    |                        |   |  |  |  |  |  |  |
| +\$14 |    | INTERNAL REGISTER            |   |    |                        |   |  |  |  |  |  |  |
| +\$16 |    | INTERNAL REGISTER            |   |    |                        |   |  |  |  |  |  |  |
| +\$18 |    |                              |   |    | DATA OUTPUT BUFFER ——— |   |  |  |  |  |  |  |
| +\$1A |    |                              |   |    | DATA GOTFOT BOFFER     |   |  |  |  |  |  |  |
| +\$1C |    |                              |   |    | INTERNAL REGISTER      |   |  |  |  |  |  |  |
| +\$1E |    |                              |   |    | INTERNAL REGISTER      |   |  |  |  |  |  |  |

Figure B-11. MC68020 and MC68030 Short Bus Cycle Stack Frame, Format \$A



Figure B-12. MC68020 and MC68030 Long Bus Cycle Stack Frame, Format \$B

|       | 15 | 15                                     |     |      |                         |  |  |  |  |  |  |  |
|-------|----|----------------------------------------|-----|------|-------------------------|--|--|--|--|--|--|--|
| SP->  |    | STATUS REGISTER                        |     |      |                         |  |  |  |  |  |  |  |
| +\$02 |    | F                                      | RET | URN  | PROGRAM COUNTER HIGH    |  |  |  |  |  |  |  |
|       |    | F                                      | RET | ΓURN | PROGRAM COUNTER LOW     |  |  |  |  |  |  |  |
| +\$06 | 1  | 1                                      | 0   | 0    | VECTOR OFFSET           |  |  |  |  |  |  |  |
| +\$08 |    |                                        |     | FA   | ULTED ADDRESS HIGH      |  |  |  |  |  |  |  |
|       |    |                                        |     | FA   | ULTED ADDRESS LOW       |  |  |  |  |  |  |  |
| +\$0C |    |                                        |     |      | DBUF HIGH               |  |  |  |  |  |  |  |
|       |    | DBUF LOW                               |     |      |                         |  |  |  |  |  |  |  |
| +\$10 | CL | CURRENT INSTRUCTION PROG. COUNTER HIGH |     |      |                         |  |  |  |  |  |  |  |
|       | Cl | CURRENT INSTRUCTION PROG. COUNTER LOW  |     |      |                         |  |  |  |  |  |  |  |
| +\$14 |    | INT                                    | ER  | NAL  | TRANSFER COUNT REGISTER |  |  |  |  |  |  |  |
| +\$16 | 0  | 0                                      |     | SP   | ECIAL STATUS WORD       |  |  |  |  |  |  |  |

Figure B-13. CPU32 Bus Error for Prefetches and Operands Stack Frame, Format \$C

|       | 15 |                                        |     |      | 0                       |  |  |  |  |  |  |  |
|-------|----|----------------------------------------|-----|------|-------------------------|--|--|--|--|--|--|--|
| SP->  |    | STATUS REGISTER                        |     |      |                         |  |  |  |  |  |  |  |
| +\$02 |    |                                        | RET | URN  | PROGRAM COUNTER HIGH    |  |  |  |  |  |  |  |
|       |    |                                        | RE1 | ΓURN | PROGRAM COUNTER LOW     |  |  |  |  |  |  |  |
| +\$06 | 1  | 1                                      | 0   | 0    | VECTOR OFFSET           |  |  |  |  |  |  |  |
| +\$08 |    |                                        |     | FA   | ULTED ADDRESS HIGH      |  |  |  |  |  |  |  |
|       |    | FAULTED ADDRESS LOW                    |     |      |                         |  |  |  |  |  |  |  |
| +\$0C |    | DBUF HIGH                              |     |      |                         |  |  |  |  |  |  |  |
|       |    | DBUF LOW                               |     |      |                         |  |  |  |  |  |  |  |
| +\$10 | CL | CURRENT INSTRUCTION PROG. COUNTER HIGH |     |      |                         |  |  |  |  |  |  |  |
|       | CL | CURRENT INSTRUCTION PROG. COUNTER LOW  |     |      |                         |  |  |  |  |  |  |  |
| +\$14 |    | IN.                                    | TER | NAL  | TRANSFER COUNT REGISTER |  |  |  |  |  |  |  |
| +\$16 | 0  | 1                                      |     | SP   | PECIAL STATUS WORD      |  |  |  |  |  |  |  |

Figure B-14. CPU32 Bus Error on MOVEM Operand Stack Frame, Format \$C



Figure B-15. CPU32 Four- and Six-Word Bus Error Stack Frame, Format \$C

### **B.3 FLOATING-POINT STACK FRAMES**

Figures B-16 through B-23 illustrate floating-point stack frames for the MC68881/MC68882 and the MC68040.



Figure B-16. MC68881/MC68882 and MC68040 Null Stack Frame



Figure B-17. MC68881 Idle Stack Frame



Figure B-18. MC68881 Busy Stack Frame



Figure B-19. MC68882 Idle Stack Frame



Figure B-20. MC68882 Busy Stack Frame





Figure B-23. MC68040 Busy Stack Frame

# APPENDIX C S-RECORD OUTPUT FORMAT

The S-record format for output modules is for encoding programs or data files in a printable format for transportation between computer systems. The transportation process can be visually monitored, and the S-records can be easily edited.

#### C.1 S-RECORD CONTENT

Visually, S-records are essentially character strings made of several fields that identify the record type, record length, memory address, code/data, and checksum. Each byte of binary data encodes as a two- character hexadecimal number: the first character represents the high- order four bits, and the second character represents the low-order four bits of the byte. Figure C-1 illustrates the five fields that comprise an S-record. Table C-1 lists the composition of each S- record field.

| TYPE | RECORD LENGTH | ADDRESS | CODE/DATA | CHECKSUM |
|------|---------------|---------|-----------|----------|

Figure C-1. Five Fields of an S-Record

Table C-1. Field Composition of an S-Record

| Field         | Printable<br>Characters | Contents                                                                                                                                                                                                                               |
|---------------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Туре          | 2                       | S-record type—S0, S1, etc.                                                                                                                                                                                                             |
| Record Length | 2                       | The count of the character pairs in the record, excluding the type and record length.                                                                                                                                                  |
| Address       | 4, 6, or 8              | The 2-, 3-, or 4-byte address at which the data field is to be loaded into memory.                                                                                                                                                     |
| Code/Data     | 0–2n                    | From 0 to n bytes of executable code, memory loadable data, or descriptive information. For compatibility with teletypewriters, some programs may limit the number of bytes to as few as 28 (56 printable characters in the S-record). |
| Checksum      | 2                       | The least significant byte of the one's complement of the sum of the values represented by the pairs of characters making up the record length, address, and the code/data fields.                                                     |

When downloading S-records, each must be terminated with a CR. Additionally, an S-record may have an initial field that fits other data such as line numbers generated by some timesharing systems. The record length (byte count) and checksum fields ensure transmission accuracy.

#### C.2 S-RECORD TYPES

There are eight types of S-records to accommodate the encoding, transportation, and decoding functions. The various Motorola record transportation control programs (e.g. upload, download, etc.), cross assemblers, linkers, and other file creating or debugging programs, only utilize S-records serving the programOs purpose. For more information on support of specific S-records, refer to the userOs manual for that program.

An S-record format module may contain S-records of the following types:

- S0 The header record for each block of S-records. The code/data field may contain any descriptive information identifying the following block of S-records. Under VERSAdos, the resident linkerOs IDENT command can be used to designate module name, version number, revision number, and description information that will make up the header record. The address field is normally zeros.
- S1 A record containing code/data and the 2-byte address at which the code/data is to reside.
- S2 A record containing code/data and the 3-byte address at which the code/data is to reside.
- S3 A record containing code/data and the 4-byte address at which the code/data is to reside.
- S5 A record containing the number of S1, S2, and S3 records transmitted in a particular block. This count appears in the address field. There is no code/data field.
- S7 A termination record for a block of S3 records. The address field may optionally contain the 4-byte address of the instruction to which control is to be passed. There is no code/data field.
- S8 A termination record for a block of S2 records. The address field may optionally contain the 3-byte address of the instruction to which control is to be passed. There is no code/data field.
- S9 A termination record for a block of S1 records. The address field may optionally contain the 2-byte address of the instruction to which control is to be passed. Under VERSAdos, the resident linkerOs ENTRY command can be used to specify this address. If this address is not specified, the first entry point specification encountered in the object module input will be used. There is no code/data field.

Each block of S-records uses only one termination record. S7 and S8 records are only active when control is to be passed to a 3- or 4- byte address; otherwise, an S9 is used for termination. Normally, there is only one header record, although it is possible for multiple header records to occur.

### C.3 S-RECORD CREATION

Dump utilities, debuggers, a VERSAdos resident linkage editor, or cross assemblers and linkers produce S-record format programs. On VERSAdos systems, the build load module (MBLM) utility allows an executable load module to be built from S-records. It has a counterpart utility in BUILDS that allows an S-record file to be created from a load module.

Programs are available for downloading or uploading a file in S- record format from a host system to an 8- or 16-bit microprocessor- based system. A typical S-record-format module is printed or displayed as follows:

\$00600004844521B \$1130000285F245F2212226A000424290008237C2A \$11300100002000800082629001853812341001813 \$113002041E900084E42234300182342000824A952 \$107003000144ED492 \$9030000FC

The module has an S0 record, four S1 records, and an S9 record. The following character pairs comprise the S-record-format module.

#### S0 Record:

- S0 S-record type S0, indicating that it is a header record.
- 06 Hexadecimal 06 (decimal 6), indicating that six character pairs (or ASCII bytes) follow.
- 0000—A 4-character, 2-byte address field; zeros in this example.
- 48 ASCII H
- 44 ASCII D
- 52 ASCII R
- 1B The checksum.

#### First S1 Record:

- S1 S-record type S1, indicating that it is a code/data record to be loaded/verified at a 2-byte address.
- 13 Hexadecimal 13 (decimal 19), indicating that 19 character pairs, representing 19 bytes of binary data, follow.
- 0000—A 4-character, 2-byte address field (hexadecimal address 0000) indicating where the data that follows is to be loaded.

The next 16 character pairs of the first S1 record are the ASCII bytes of the actual program code/data. In this assembly language example, the programOs hexadecimal opcodes are sequentially written in the code/data fields of the S1 records.

| Opcode   |        | Instruction              |
|----------|--------|--------------------------|
| 285F     | MOVE.L | (A7) +, A4               |
| 245F     | MOVE.L | (A7) +, A2               |
| 2212     | MOVE.L | (A2), D1                 |
| 226A0004 | MOVE.L | 4(A2), A1                |
| 24290008 | MOVE.L | FUNCTION(A1), D2         |
| 237C     | MOVE.L | #FORCEFUNC, FUNCTION(A1) |

The rest of this code continues in the remaining S1 recordOs code/data fields and stores in memory location 0010, etc.

2A — The checksum of the first S1 record.

The second and third S1 records also contain hexadecimal 13 (decimal 19) character pairs and end with checksums 13 and 52, respectively. The fourth S1 record contains 07 character pairs and has a checksum of 92.

#### S9 Record:

S9 — S-record type S9, indicating that it is a termination record.

03 — Hexadecimal 03, indicating that three character pairs (3 bytes) follow.

0000—The address field, zeros.

FC — The checksum of the S9 record.

Each printable character in an S-record encodes in hexadecimal (ASCII in this example) representation of the binary bits that transmit. Figure C-2 illustrates the sending of the first S1 record. Table C-2 lists the ASCII code for S-records.

Figure C-2. Transmission of an S1 Record

Table C-2. ASCII Code

| Least<br>Significant | Most Significant Digit |     |    |   |   |   |   |     |  |  |
|----------------------|------------------------|-----|----|---|---|---|---|-----|--|--|
| Digit                | 0                      | 1   | 2  | 3 | 4 | 5 | 6 | 7   |  |  |
| 0                    | NUL                    | DLE | SP | 0 | @ | Р |   | р   |  |  |
| 1                    | SOH                    | DC1 | !  | 1 | Α | Q | а | q   |  |  |
| 2                    | STX                    | DC2 | ££ | 2 | В | R | b | r   |  |  |
| 3                    | ETX                    | DC3 | #  | 3 | С | S | С | s   |  |  |
| 4                    | EOT                    | DC4 | \$ | 4 | D | Т | d | t   |  |  |
| 5                    | ENQ                    | NAK | %  | 5 | Е | U | е | u   |  |  |
| 6                    | ACK                    | SYN | &  | 6 | F | V | f | V   |  |  |
| 7                    | BEL                    | ETB | ,  | 7 | G | W | g | w   |  |  |
| 8                    | BS                     | CAN | (  | 8 | Н | Х | h | х   |  |  |
| 9                    | HT                     | EM  | )  | 9 | I | Υ | i | у   |  |  |
| А                    | LF                     | SUB | *  | : | J | Z | j | z   |  |  |
| В                    | VT                     | ESC | +  | ; | K | [ | k | {   |  |  |
| С                    | FF                     | FS  | ,  | < | L | \ | I | I   |  |  |
| D                    | CR                     | GS  | _  | = | М | ] | m | }   |  |  |
| E                    | SO                     | RS  |    | > | N | ^ | n | ~   |  |  |
| F                    | SI                     | US  | /  | ? | 0 | _ | 0 | DEL |  |  |