# USER'S MANUAL # V850 FAMILY TM 32-/16-BIT SINGLE-CHIP MICROCONTROLLER # **ARCHITECTURE** V851<sup>TM</sup> V852<sup>TM</sup> V853<sup>TM</sup> V854<sup>TM</sup> #### NOTES FOR CMOS DEVICES - #### (1) PRECAUTION AGAINST ESD FOR SEMICONDUCTORS Note: Strong electric field, when exposed to a MOS device, can cause destruction of the gate oxide and ultimately degrade the device operation. Steps must be taken to stop generation of static electricity as much as possible, and quickly dissipate it once, when it has occurred. Environmental control must be adequate. When it is dry, humidifier should be used. It is recommended to avoid using insulators that easily build static electricity. Semiconductor devices must be stored and transported in an anti-static container, static shielding bag or conductive material. All test and measurement tools including work bench and floor should be grounded. The operator should be grounded using wrist strap. Semiconductor devices must not be touched with bare hands. Similar precautions need to be taken for PW boards with semiconductor devices on it. #### ② HANDLING OF UNUSED INPUT PINS FOR CMOS Note: No connection for CMOS device inputs can be cause of malfunction. If no connection is provided to the input pins, it is possible that an internal input level may be generated due to noise, etc., hence causing malfunction. CMOS devices behave differently than Bipolar or NMOS devices. Input levels of CMOS devices must be fixed high or low by using a pull-up or pull-down circuitry. Each unused pin should be connected to VDD or GND with a resistor, if it is considered to have a possibility of being an output pin. All handling related to the unused pins must be judged device by device and related specifications governing the devices. #### ③ STATUS BEFORE INITIALIZATION OF MOS DEVICES Note: Power-on does not necessarily define initial status of MOS device. Production process of MOS does not define the initial operation status of the device. Immediately after the power source is turned ON, the devices with reset function have not yet been initialized. Hence, power-on does not guarantee out-pin levels, I/O settings or contents of registers. Device is not initialized until the reset signal is received. Reset operation must be executed immediately after power-on for devices having reset function. V800 Series, V810 Family, V830 Family, V850 Family, V805, V810, V820, V821, V830, V851, V852, V853, and V854 are trademarks of NEC Corporation. UNIX is a registered trademark licensed by X/Open Company Limited in the US and other countries. Windows is a trademark of Microsoft Corporation. The export of these products from Japan is regulated by the Japanese government. The export of some or all of these products may be prohibited without governmental license. To export or re-export some or all of these products from a country other than Japan may also be prohibited without a license from that country. Please call an NEC sales representative. #### The information in this document is subject to change without notice. No part of this document may be copied or reproduced in any form or by any means without the prior written consent of NEC Corporation. NEC Corporation assumes no responsibility for any errors which may appear in this document. NEC Corporation does not assume any liability for infringement of patents, copyrights or other intellectual property rights of third parties by or arising from use of a device described herein or any other liability arising from use of such device. No license, either express, implied or otherwise, is granted under any patents, copyrights or other intellectual property rights of NEC Corporation or others. While NEC Corporation has been making continuous effort to enhance the reliability of its semiconductor devices, the possibility of defects cannot be eliminated entirely. To minimize risks of damage or injury to persons or property arising from a defect in an NEC semiconductor device, customers must incorporate sufficient safety measures in its design, such as redundancy, fire-containment, and anti-failure features. NEC devices are classified into the following three quality grades: "Standard", "Special", and "Specific". The Specific quality grade applies only to devices developed based on a customer designated "quality assurance program" for a specific application. The recommended applications of a device depend on its quality grade, as indicated below. Customers must check the quality grade of each device before using it in a particular application. Standard: Computers, office equipment, communications equipment, test and measurement equipment, audio and visual equipment, home electronic appliances, machine tools, personal electronic equipment and industrial robots Special: Transportation equipment (automobiles, trains, ships, etc.), traffic control systems, anti-disaster systems, anti-crime systems, safety equipment and medical equipment (not specifically designed for life support) Specific: Aircrafts, aerospace equipment, submersible repeaters, nuclear reactor control systems, life support systems or medical equipment for life support, etc. The quality grade of NEC devices is "Standard" unless otherwise specified in NEC's Data Sheets or Data Books. If customers intend to use NEC devices for applications other than those specified for Standard quality grade, they should contact an NEC sales representative in advance. Anti-radioactive design is not implemented in this product. # **Regional Information** Some information contained in this document may vary from country to country. Before using any NEC product in your application, please contact the NEC office in your country to obtain a list of authorized representatives and distributors. They will verify: - · Device availability - Ordering information - · Product release schedule - · Availability of related technical literature - Development environment specifications (for example, specifications for third-party tools and components, host computers, power plugs, AC supply voltages, and so forth) - Network requirements In addition, trademarks, registered trademarks, export restrictions, and other legal issues may also vary from country to country. #### **NEC Electronics Inc. (U.S.)** Mountain View, California Tel: 800-366-9782 Fax: 800-729-9288 #### **NEC Electronics (Germany) GmbH** Duesseldorf, Germany Tel: 0211-65 03 02 Fax: 0211-65 03 490 #### **NEC Electronics (UK) Ltd.** Milton Keynes, UK Tel: 01908-691-133 Fax: 01908-670-290 #### NEC Electronics Italiana s.r.1. Milano, Italy Tel: 02-66 75 41 Fax: 02-66 75 42 99 #### **NEC Electronics (Germany) GmbH** Benelux Office Eindhoven, The Netherlands Tel: 040-2445845 Fax: 040-2444580 #### **NEC Electronics (France) S.A.** France Tel: 01-30-67 58 00 Fax: 01-30-67 58 99 #### **NEC Electronics (France) S.A.** Spain Office Madrid, Spain Tel: 01-504-2787 Fax: 01-504-2860 #### **NEC Electronics (Germany) GmbH** Scandinavia Office Taeby Sweden Tel: 8-63 80 820 Fax: 8-63 80 388 #### **NEC Electronics Hong Kong Ltd.** Hong Kong Tel: 2886-9318 Fax: 2886-9022/9044 #### **NEC Electronics Hong Kong Ltd.** Seoul Branch Seoul, Korea Tel: 02-528-0303 Fax: 02-528-4411 #### **NEC Electronics Singapore Pte. Ltd.** United Square, Singapore 1130 Tel: 253-8311 Fax: 250-3583 #### **NEC Electronics Taiwan Ltd.** Taipei, Taiwan Tel: 02-719-2377 Fax: 02-719-5951 #### NEC do Brasil S.A. Sao Paulo-SP, Brasil Tel: 011-889-1680 Fax: 011-889-1689 #### **Main Revisions in this Edition** | Page | Description | | | | |---------|--------------------------------------------------------------------------|--|--|--| | General | V854 is added to target device | | | | | p. 3 | Figure of 1.3 Product Development is modified. | | | | | p. 7 | Remark of Figure 2-2. Program Register Operations is modified. | | | | | p. 18 | Addition of description to 4.1 Memory Map | | | | | p. 33 | SR is added to 5.3 Instruction Set Operation | | | | | p. 67 | Addition of description to <b>Remark</b> of Saturated Add | | | | | p. 68 | Addition of description to <b>Remark</b> of Saturated Subtract | | | | | p. 69 | Addition of description to <b>Remark</b> of Saturated Subtract Immediate | | | | | p. 70 | Addition of description to <b>Remark</b> of Saturated Subtract Reverse | | | | The mark $\star$ shows major revised points. #### **PREFACE** #### Readers This manual is intended for users who understand the functions of the V850 family in designing systems using the products of the V850 family. #### **Purpose** This manual presents information on the architecture and instruction set of the V850 family. V850 Family Products • V851 : μPD703000, 703001, 70P3000 V852 : μPD703002, 70P3002 V853<sup>Note</sup> : μPD703003, 70F3003 • V854 $^{\text{Note}}$ : $\mu$ PD703008, 70F3008, 703008Y, 70F3008Y Note Under development #### Organization This manual contains the following information: - Register set - Data type - Instruction format and instruction set - Interrupt and exception - Pipeline operation #### How to read this manual It is assumed that the readers of this manual have general knowledge of electronics engineering, logic circuits, and microcontrollers. To learn about the hardware functions, → Read the **User's Manual – Hardware** of each device. To learn about the functions of a specific instruction in detail, → Read CHAPTER 5 INSTRUCTION. To learn about the electrical specifications, $\rightarrow$ Read the **DATA SHEET** of each device. To understand the overall functions of the V850 family, $\rightarrow$ Read this manual in the order of Contents. With the V850 family, data consisting of 2 bytes is called a half-word, and data consisting of 4 bytes is called a word. Legend Data significance : Most significant bits on the left, and least significant bits on the right. Active low : $\overline{\times}$ (bar over pin or signal name) Memory map address : Top - high, bottom - low : Footnote Caution : Important information Remark : Supplement Numeric representation : Binary ... $\times\!\times\!\times\!\times$ or $\times\!\times\!\times\!B$ Decimal ... xxxx Hexadecimal ... ××××H Prefixes representing an exponent of 2 (for address space or memory capacity): K (Kilo) : $2^{10} = 1024$ M (Mega) : $2^{20} = 1024^2$ G (Giga) : $2^{30} = 1024^3$ **Related Documents** The related documents indicated here may include preliminary version. However, preliminary versions are not marked as such. #### Device related documents | Document Name | Data Sheet | User's Manual | | Application Table | | |---------------|---------------------------------------------------------------|---------------|--------------|-------------------|-------------| | Product Name | Data Sneet | Hardware | Architecture | Register | Instruction | | V851 | U10987E <sup>Note 1</sup><br>U10988E <sup>Note 2</sup> | U10935E | U10243E | U10662E | U10229E | | V852 | U11826E <sup>Note 3</sup><br>U11827E <sup>Note 4</sup> | U10038E | | U10513E | | | V853 | To be prepared <sup>Note 5</sup><br>U12036E <sup>Note 6</sup> | U10913E | | _ | | | V854 | To be prepared | U10969E | | _ | | **Notes 1.** $\mu$ PD703000, 703001 - **2.** μPD70P3000 - **3.** μPD703002 - **4.** μPD70P3002 - **5.** μPD703003 - **6.** μPD70F3003 ## • Development tool related documents (user's manual) | | Document Number | | |-----------------------------------------------|--------------------------|----------------| | IE-703002-MC (Incircuit emulator) | U11595E | | | IE-703003-MC-EM1 (V853 peripher | U11596E | | | IE-703008-MC-EM1 (V854 peripher | ral I/O board) | To be prepared | | CA850 (C compiler package) | Operation UNIX™ based | U11013E | | | Operation Windows™ based | U11068E | | | C language | U11010E | | | Assembly language | U10543E | | RX850 (Real-time OS) | Fundamental | U11037E | | | Technical | U11117E | | | Nucleus Installation | U11038E | | | Debugger Windows based | U11158E | | AZ850 (System performance analyzer) Operation | | U11181E | | ID850 (C source debugger) | Operation UNIX based | U12209E | | | Operation Windows based | U11196E | | Installation UNIX based | | U12210E | #### **CONTENTS** | CHAPTI | ER 1 INTRODUCTION | |--------|-------------------------------------------------| | 1.1 | General | | 1.2 | Architecture Features | | 1.3 | Product Development | | 1.4 | CPU Configuration | | | | | CHAPTI | ER 2 REGISTER SET | | 2.1 | Program Registers | | | 2.1.1 Program register set | | 2.2 | System Registers | | | 2.2.1 Interrupt status saving registers | | | 2.2.2 NMI status saving registers | | | 2.2.3 Exception cause register | | | 2.2.4 Program status word | | | 2.2.5 System register number | | | | | CHAPTI | ER 3 DATA TYPE 1; | | 3.1 | Data Format | | | 3.1.1 Data type and addressing | | 3.2 | Data Representation | | | 3.2.1 Integer | | | 3.2.2 Unsigned integer | | | 3.2.3 Bit | | 3.3 | Data Alignment | | | | | CHAPTI | ER 4 ADDRESS SPACE 1 | | 4.1 | Memory Map 18 | | 4.2 | Addressing Mode 19 | | | 4.2.1 Instruction address | | | 4.2.2 Operand address | | | | | | ER 5 INSTRUCTION 25 | | 5.1 | Instruction Format | | 5.2 | Outline of Instructions | | 5.3 | Instruction Set | | 5.4 | Number of Instruction Execution Clock Cycles 96 | | | | | CHAPTI | ER 6 INTERRUPT AND EXCEPTION9 | | 6.1 | Interrupt Servicing94 | | | 6.1.1 Maskable interrupt | | | 6.1.2 Non-maskable interrupt | | 6.2 | Exception Processing | | | 6.2.1 Software exception | | | 6.2.2 Exception trap | | 63 | Restoring from Interrunt/Exception 9 | | CHAPT | ER 7 | RESET | 101 | |---------|---------|--------------------------------------------------------------------------------|-----| | 7.1 | Initial | lizing | 101 | | 7.2 | Starti | ing Up | 101 | | CHAPTI | ER 8 | PIPELINE | 103 | | 8.1 | | ne of Operation | | | 8.2 | | ine Flow During Execution of Instructions | | | | 8.2.1 | Load instructions | | | | 8.2.2 | Store instructions | 104 | | | 8.2.3 | Arithmetic operation instructions (excluding multiply and divide instructions) | 104 | | | 8.2.4 | Multiply instructions | 105 | | | 8.2.5 | Divide instructions | 105 | | | 8.2.6 | Logical operation instructions | 105 | | | 8.2.7 | Saturation operation instructions | 106 | | | 8.2.8 | Branch instruction | 106 | | | 8.2.9 | Bit manipulation instructions | 107 | | | 8.2.10 | Special instructions | 108 | | 8.3 | Pipel | ine Disorder | 110 | | | 8.3.1 | Alignment hazard | 110 | | | 8.3.2 | Referencing execution result of load instruction | 111 | | | 8.3.3 | Referencing execution result of multiply instruction | 111 | | | 8.3.4 | Referencing execution result of LDSR instruction for EIPC and FEPC | 112 | | | 8.3.5 | Cautions when creating programs | 112 | | 8.4 | Addit | ional Items Related to Pipeline | 113 | | | 8.4.1 | Harvard architecture | 113 | | | 8.4.2 | Short path | 114 | | APPEN | DIX A | INSTRUCTION MNEMONIC (IN ALPHABETICAL ORDER) | 115 | | APPEN | DIX B | INSTRUCTION LIST | 123 | | APPEN | DIX C | INSTRUCTION OP CODE MAP | 125 | | INDEX . | | | 127 | #### LIST OF FIGURES | Figure No. | Title | Page | |------------|-----------------------------------------------------|------| | 1-1 | Internal Configuration | 4 | | 2-1 | Program Registers | 6 | | 2-2 | Program Register Operations | 7 | | 2-3 | System Registers | 8 | | 4-1 | Memory Map | 18 | | 4-2 | Relative Addressing (JR disp22/JARL disp22, reg2) | 19 | | 4-3 | Relative Addressing (Bcond disp9) | 20 | | 4-4 | Register Addressing (JMP [reg1]) | 21 | | 4-5 | Based Addressing | 22 | | 4-6 | Based Addressing | 23 | | 4-7 | Bit Addressing | 24 | | 6-1 | Maskable Interrupt Servicing Format | 95 | | 6-2 | Non-maskable Interrupt Servicing Format | 96 | | 6-3 | Software Exception Processing Format | 97 | | 6-4 | Illegal Instruction Code | 98 | | 6-5 | Exception Trap Processing Format | 98 | | 6-6 | Restoration from Interrupt/Exception | 99 | | 8-1 | Example of Executing Nine Standard Instructions | 103 | | 8-2 | Access Times (in clocks) | 104 | | 8-3 | Align Hazard Example | 110 | | 8-4 | Example of Execution Result of Load Instruction | 111 | | 8-5 | Example of Execution Result of Multiply Instruction | 111 | #### LIST OF TABLES | Table No. | Title | Page | |-----------|------------------------------------------------------|------| | 2-1 | System Register Number | 11 | | 5-1 | Load/Store Instructions | 28 | | 5-2 | Arithmetic Operation Instructions | 28 | | 5-3 | Saturated Operation Instructions | 29 | | 5-4 | Logical Operation Instructions | 29 | | 5-5 | Branch Instructions | 30 | | 5-6 | Bit Manipulation Instructions | 31 | | 5-7 | Special Instructions | 31 | | 5-8 | Conditional Branch Instructions | 41 | | 5-9 | Condition Codes | 72 | | 5-10 | List of Number of Instruction Execution Clock Cycles | 90 | | 6-1 | Interrupt/Exception Codes | 94 | | 7-1 | Register Status after Reset | 101 | | A-1 | Instruction Mnemonic (in alphabetical order) | 116 | | B-1 | Mnemonic List | 123 | | B-2 | Instruction Set | 124 | #### **CHAPTER 1 INTRODUCTION** The V850 family is a collection of NEC's single-chip microcontrollers that have a CPU core using the RISC microprocessor technology of the V800 Series<sup>™</sup>, with on-chip ROM/RAM and peripheral I/Os, etc. The V850 family of microcontrollers provides a migration path to the existing NEC's original single-chip microcontroller "78K Series", and boasts higher cost-performance. This chapter briefly outlines the V850 family. #### 1.1 General Real-time control systems are used in a wide range of applications, including: - office equipment such as HDDs (Hard Disk Drives), PPCs (Plain Paper Copiers), printers, and facsimiles, - automobile electronics such as engine control systems and ABSs (Antilock Braking Systems), and - factory automation equipment such as NC (Numerical Control) machine tools and various controllers. The great majority of these systems employed 8-bit or 16-bit microcontrollers so far. However,the performance level of these microcontrollers has become inadequate in recent years as control operations have risen in complexity, leading to the development of increasingly complicated instruction sets and hardware design. As a result, the need has arisen for a new generation of microcontrollers operable at much higher frequencies to achieve an acceptable level of performance under today's more demanding requirements. The V850 family of microcontrollers was developed to satisfy this need. This family uses RISC architecture that can provide maximum performance with simpler hardware, allowing users to obtain a performance approximately 15 times higher than that of the existing 78K/III Series and 78K/IV Series CISC single-chip microcontrollers at a lower total cost. In addition to the basic instructions of conventional RISC CPUs, the V850 family is provided with special instructions such as saturate, bit manipulate, and multiply/divide (executed by a hardware multiplier) instructions, which are especially suited for digital servo control systems. Moreover, instruction formats are designed for maximum compiler coding efficiency, allowing the reduction of object code sizes. #### 1.2 Architecture Features - High-performance 32-bit architecture for embedded control - Number of instructions: 74 - 32-bit general registers : 32 - · Load/store instructions in long/short format - 3-operand instruction - 5-stage pipeline of 1 clock cycle per stage - Hardware interlock on register/flag hazards - Memory space Program space : 16 MB linear - Data space : 4 GB linear - Special instructions - Saturation operation instructions - · Bit manipulation instructions - On-chip multiplier executing multiplication in 1 to 2 clocks (16 bits $\times$ 16 bits $\rightarrow$ 32 bits) #### 1.3 Product Development The V850 family is part of the V800 Series and consists of single-chip microcontrollers using a RISC microprocessor core. While the V810 family<sup>™</sup> of microprocessors is intended for data processing, the V850 family is targeted for embedded control systems, and can be used in a wide variety of applications. #### ★ Product development ## 1.4 CPU Configuration Figure 1-1 shows the internal configuration of the V850 family. Internal ROM CPU BCU Instruction РС queue ROM/ **PROM** 32-bit barrel shifter Prefetch Multiplier control System $16\times16\rightarrow32$ register Internal peripheral I/O Internal RAM General register ALU $32 \text{ bits} \times 32$ Bus control Internal bus Figure 1-1. Internal Configuration The function of each hardware block is as follows: | CPU | Executes almost all instructions such as address calculation, arithmetic and logical operation, and data transfer in one clock by using a 5-stage pipeline. Contains dedicated hardware such as a multiplier ( $16 \times 16$ bits) and a barrel shifter ( $32$ bits/clock) to execute complicated instructions at high speeds. | |-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Internal ROM | ROM or EPROM mapped from address 00000000H. Can be accessed by the CPU in one clock during instruction fetch. | | Internal RAM | RAM mapped to a space preceding address FFFFEFFH. Can be accessed by the CPU in one clock during data access. | | Internal peripheral I/O | Peripheral I/O area mapped from address FFFF000H. | | BCU | Starts a necessary bus cycle based on a physical address obtained by the CPU. If the CPU does not issue a request for starting a bus cycle, the BCU generates a prefetch address, and prefetches an instruction code. The prefetched instruction code is loaded to an internal instruction queue. | #### **CHAPTER 2 REGISTER SET** The registers of the V850 family can be classified into two types: program register sets that can be used for general programming, and system registers that can control the execution environment. All the registers are 32 bits wide. #### 2.1 Program Registers #### 2.1.1 Program register set #### (1) General registers The V850 family has thirty-two general registers, r0 through r31. All these registers can be used for data or address storage. However, r0 and r30 are implicitly used by instructions, and care must be exercised in using these registers. r0 is a register that always holds 0, and is used for operations and offset 0 addressing. r30 is used as a base pointer when accessing memory using the SLD and SST instructions. r1, r2, r3, r4, r5, and r31 are implicitly used by the assembler and C compiler. Before using these registers, therefore, their contents must be saved so that they are not lost. The contents must be restored to the registers after the registers have been used. Figure 2-1. Program Registers 31 0 r0 Zero Register Reserved for Address Generation r1 r2 Interrupt Stack Pointer r3 Stack Pointer (SP) Global Pointer (GP) r4 r5 Text Pointer (TP) r6 r7 r8 r9 r10 r11 r12 r13 r14 r15 r16 r17 r18 r19 r20 r21 r22 r23 r24 r25 r26 r27 r28 r29 r30 Element Pointer (EP) r31 Link pointer (LP) PC Program Counter Figure 2-2. Program Register Operations | Name | Usage | Operation | |----------------------|-----------------------------|----------------------------------------------------------------------------| | r0 | Zero register | Always holds 0. | | r1 | Assembler-reserved register | Used as working register for address generation. | | r2 | Interrupt stack pointer | Used as stack pointer for interrupt handler. | | r3 | Stack pointer | Used for stack frame generation when function is called. | | r4 | Global pointer | Used to access global variable in data area. | | r5 | Text pointer | Used as register for pointing start address of text area <sup>Note</sup> . | | r6<br>through<br>r29 | | Address/data variable registers | | r30 | Element pointer | Used as base pointer for address generation when memory is accessed. | | r31 | Link pointer | Used when compiler calls function. | | PC | Program counter | Holds instruction address during program execution. | Note Text area: Area where program code is placed. Remark For detailed descriptions of r1 to r31 used by assembler and C compiler, see the C compiler package (CA850) User's Manual. #### (2) Program counter This register holds an instruction address during program execution. The lower 24 bits of this register are valid, and bits 31 through 24 are reserved fields (fixed to 0). If a carry occurs from bit 23 to 24, it is ignored. Bit 0 is always fixed to 0, and execution cannot branch to an odd address. Remark RFU: Reserved field (Reserved for Future Use) #### 2.2 System Registers The system registers control the status of the V850 family and holds information on interrupts. Figure 2-3. System Registers #### 2.2.1 Interrupt status saving registers Two interrupt status saving registers are provided: EIPC and EIPSW. The contents of the PC and PSW are respectively saved in these registers if an exception or interrupt occurs. If the NMI occurs, however, the contents of the PC and PSW are saved to NMI status saving registers. When an exception or interrupt occurs, the address of the following instruction is saved in the EIPC register. If an interrupt occurs while a division (DIVH) instruction is executed, the address of the division instruction currently being executed is saved. The current value of the PSW is saved to the EIPSW. Because only one pair of interrupt status saving registers is provided, the contents of these registers must be saved by program when multiple interrupts are enabled. Bits 24 through 31 of the EIPC and bits 8 through 31 of the EIPSW are fixed to 0. #### 2.2.2 NMI status saving registers The V850 family is provided with two NMI status saving registers: FEPC and FEPSW. The contents of the PC and PSW are respectively saved in these registers when an NMI occurs. The value saved to the FEPC is, like the EIPC, the address of the instruction next to the one executed when the NMI has occurred (if the NMI occurs while a division (DIVH) instruction is executed, the address of the division instruction under execution is saved). The current value of the PSW is saved to the FEPSW. Bits 24 through 31 of the FEPC and bits 8 through 31 of the FEPSW are fixed to 0. #### 2.2.3 Exception cause register The exception cause register (ECR) holds the cause information of an exception, maskable interrupt, or NMI when any of these events occur. The ECR holds a code which identifies each interrupt source. This is a read-only register, and therefore, no data can be written to it by using the LDSR instruction. | Bit Position | Field | Function | | | |--------------|-------|---------------------------------------------------------|--|--| | 31 - 16 | FECC | Fatal Error Cause Code<br>NMI code | | | | 15 - 0 | EICC | Exception/Interrupt Cause Code Exception/interrupt code | | | #### 2.2.4 Program status word The program status word is a collection of flags that indicate the status of the program (result of instruction execution) and the status of the CPU. If the contents of the PSW register are modified by the LDSR instruction, the PSW will assume the new value immediately after the LDSR instruction has been executed. In setting the ID flag to 1, however, interrupts are already disabled even while the LDSR instruction is executing. | Bit Position | Flag | Function | | | |--------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 31 - 8 | RFU | Reserved for Future Use Reserved field (fixed to 0). | | | | 7 | NP | NMI Pending Indicates that NMI processing is in progress. This flag is set when NMI is granted. The NMI request is then masked, and multiple interrupts are disabled. NP = 0: NMI processing is not in progress NP = 1: NMI processing is in progress | | | | 6 | EP | Exception Pending Indicates that exception processing is in progress. This flag is set when an exception occurs. EP = 0: Exception processing is not in progress EP = 1: Exception processing is in progress | | | | 5 | ID | Interrupt Disable Indicates whether external interrupt request can be accepted. ID = 0: Interrupt can be accepted ID = 1: Interrupt cannot be accepted | | | | 4 | SATNote | Saturated Math Result Indicates that an overflow has occurred in a saturate operation and the result is saturated. This is a cumulative flag. Once the result is saturated, the flag is set to 1 and is not reset to 0 even if the next result does not saturate. To reset this flag, load data to PSW. This flag is neither set nor reset by general arithmetic operation instruction. SAT = 0: Not saturated SAT = 1: Saturated | | | | 3 | CY | Carry Indicates whether carry or borrow occurred as a result of the operation. CY = 0: Carry or borrow did not occur CY = 1: Carry or borrow occurred | | | | 2 | OVNote | Overflow Indicates whether overflow occurred as a result of the operation. OV = 0: Overflow did not occur OV = 1: Overflow occurred | | | | 1 | SNote | Sign Indicates whether the result of the operation is negative S = 0: Result is positive or zero S = 1: Result is negative | | | | 0 | Z | Zero Indicates whether the result of the operation is zero Z = 0: Result is not zero Z = 1: Result is zero | | | **Note** In the case of saturate instructions, the SAT, S, and OV flags will be set accordingly by the result of the operation as shown in the table below. Note that the SAT flag is set to 1 only when the OV flag has been set due to an overflow condition caused by a saturate instruction. | Status of Operation Result | SAT-S-OV | | OV | Result of Saturation Processing | |------------------------------------|----------|---|----|---------------------------------| | Maximum positive value is exceeded | 1 | 0 | 1 | 7FFFFFFH | | Maximum negative value is exceeded | 1 | 1 | 1 | 80000000H | | Others | 0 | × | 0 | Operation result | #### 2.2.5 System register number Data in the system registers is accessed by using the load/store system register instructions, LDSR and STSR. Each register is assigned a unique number which is referenced by the LDSR and STSR instructions. Table 2-1. System Register Number | Number | System Register | Operand Specification | | |--------|-----------------|-----------------------|------| | | | LDSR | STSR | | 0 | EIPC | √ | √ | | 1 | EIPSW | √ | √ | | 2 | FEPC | √ | √ | | 3 | FEPSW | √ | √ | | 4 | ECR | _ | √ | | 5 | PSW | √ | √ | | 6 - 31 | Reserved | | | — : Accessing prohibited√ : Accessing enabled Reserved: Accessing registers in this range is prohibited and will lead to undefined results. Caution When using the LDSR instruction with the EIPC and FEPC registers, only even address values should be specified. After interrupt servicing has ended with a RETI instruction, bit 0 in the EIPC and FEPC registers will be ignored and assumed to be zero when the PC is restored. [MEMO] #### **CHAPTER 3 DATA TYPE** #### 3.1 Data Format The V850 family supports the following data types: - Integer (8, 16, 32 bits) - Unsigned integer (8, 16, 32 bits) - Bit #### 3.1.1 Data type and addressing The V850 family supports three types of data lengths: word (32 bits), half-word (16 bits), and byte (8 bits). Byte 0 of any data is always the least significant byte (this is called little endian) and shown at the rightmost position in figures throughout this manual. The following paragraphs describe the data format where data of fixed length is in memory. #### (1) Byte (BYTE) A byte is 8-bit contiguous data that starts from any byte boundary<sup>Note</sup>. Each bit is assigned a number from 0 to 7. The LSB (Least Significant Bit) is bit 0 and the MSB (Most Significant Bit) is bit 7. A byte is specified by its address A. #### (2) Half-word (HALF-WORD) A half-word is 2-byte (16-bit) contiguous data that starts from any half-word boundary<sup>Note</sup>. Each bit is assigned a number from 0 to 15. The LSB is bit 0 and the MSB is bit 15. A half-word is specified by its address A (with the lowest bit fixed to 0), and occupies 2 bytes A and A+1. #### (3) Word (WORD) A word is 4-byte (32-bit) contiguous data that starts from any word boundary<sup>Note</sup>. Each bit is assigned a number from 0 to 31. The LSB is bit 0 and the MSB is bit 31. A word is specified by its address A (with the 2 lowest bits fixed to 0), and occupies 4 bytes A, A+1, A+2, and A+3. #### (4) Bit (BIT) A bit is 1-bit data at the nth bit position in 8-bit data that starts from any byte boundary<sup>Note</sup>. A bit is specified by its address A and bit number n. Note Refer to 3.3 Data Alignment. #### 3.2 Data Representation #### 3.2.1 Integer With the V850 family, an integer is expressed as a binary number of 2's complement and is 8, 16, or 32 bits long. Regardless of its length, the bit 0 of an integer is the least significant bit. The higher the bit number, the more significant the bit. Because 2's complement is used, the most significant bit is used as a sign bit. | Data Length | | Range | |-------------|---------|----------------------------| | Byte | 8 bits | -128 to +127 | | Half-word | 16 bits | -32768 to +32767 | | Word | 32 bits | -2147483648 to +2147483647 | #### 3.2.2 Unsigned integer While an integer is data that can take either a positive or a negative value, an unsigned integer is an integer that is not negative. Like an integer, an unsigned integer is also expressed as 2's complement and is 8, 16, or 32 bits long. Regardless of its length, the bit 0 of an unsigned integer is the least significant bit, and the higher the bit number, the more significant the bit. However, no sign bit is used. | Data Length | | Range | |-------------|---------|-----------------| | Byte | 8 bits | 0 to 255 | | Half-word | 16 bits | 0 to 65535 | | Word | 32 bits | 0 to 4294967295 | #### 3.2.3 Bit The V850 family can handle 1-bit data that can take a value of 0 (cleared) or 1 (set). Bit manipulation can be performed only to 1-byte data in the memory space in the following four ways: - Set - Clear - Invert - Test #### 3.3 Data Alignment With the V850 family, word data to be allocated in memory must be aligned at an appropriate boundary. Therefore, word data must be aligned at a word boundary (the lower 2 bits of the address are 0), and half-word data must be aligned at a half-word boundary (the lowest bit of the address is 0). If data is not aligned at a boundary, the data is accessed with the lowest bit(s) of the address (lower 2 bits in the case of word data and lowest 1 bit in the case of half-word data) automatically masked. This will cause lost of data and truncation of the least significant bytes. Byte data can be placed at any address. [MEMO] #### **CHAPTER 4 ADDRESS SPACE** The V850 family supports a 4-GB linear address space. Both memory and I/O are mapped to this address space (**memory-mapped I/O**). The V850 family outputs 32-bit addresses to the memory and I/O. The maximum address is $2^{32}$ –1. Byte ordering is little endian. Byte data allocated at each address is defined with bit 0 as LSB and bit 7 as MSB. In regards to multiple-byte data, the byte with the lowest address value is defined to have the LSB and the byte with the highest address value is defined to have the MSB. Data consisting of 2 bytes is called a half-word, and 4-byte data is called a word. In this User's Manual, data consisting of 2 or more bytes is illustrated as below, with the lower address shown on the right and the higher address on the left. #### 4.1 Memory Map The V850 family employs a 32-bit architecture and supports a linear address space (data space) of up to 4 GB. It supports a linear address space (program space) of up to 16 MB for instruction addressing. Figure 4-1 shows the memory map of the V850 family. The capacity of the on-chip ROM and RAM depends on each product. For details, refer to the memory map section in the User's Manual-Hardware of each product. Figure 4-1. Memory Map #### 4.2 Addressing Mode The CPU generates two types of addresses: instruction addresses used for instruction fetch and branch operations; and operand addresses used for data access. #### 4.2.1 Instruction address An instruction address is determined by the contents of the program counter (PC), and is automatically incremented (+2) according to the number of bytes of an instruction to be fetched each time an instruction has been executed. When a branch instruction is executed, the branch destination address is loaded into the PC using one of the following two addressing modes: #### (1) Relative address (PC relative) The signed 9- or 22-bit data of an instruction code (displacement: disp) is added to the value of the program counter (PC). At this time, the displacement is treated as 2's complement data with bits 8 and 21 serving as sign bits. This addressing is used for Bcond disp9, JR disp22, and JARL disp22, reg2 instructions. Figure 4-2. Relative Addressing (JR disp22/JARL disp22, reg2) Figure 4-3. Relative Addressing (Bcond disp9) #### (2) Register addressing (address indirect) The contents of a general register (r0 - r31) specified by an instruction are transferred to the program counter (PC). This addressing is applied to the JMP [reg1] instruction. Figure 4-4. Register Addressing (JMP [reg1]) #### 4.2.2 Operand address When an instruction is executed, the register or memory area to be accessed is specified in one of the following four addressing modes: #### (1) Register addressing The general register (may be system register) specified in the general register specification field is accessed as operand. This addressing mode applies to instructions using the operand format reg1, reg2, or regID. #### (2) Immediate addressing The 5-bit or 16-bit data for manipulation is contained directly in the instruction. This addressing mode applies to instructions using the operand format imm5, imm16, vector, or cccc. Remark vector: Operand that is 5-bit immediate data to specify trap vector (00H-1FH), and is used in TRAP instruction. cccc : Operand consisting of 4-bit data used in SETF instruction to specify condition code. Assigned as part of instruction code as 5-bit immediate data by appending 1-bit 0 above highest bit. #### (3) Based addressing The following two types of based addressing are supported: #### (a) Type 1 The address of the data memory location to be accessed is determined by adding the value in the specified general register to the 16-bit displacement value contained in the instruction. This addressing mode applies to instructions using the operand format disp16 [reg1]. Figure 4-5. Based Addressing #### (b) Type 2 The address of the data memory location to be accessed is determined by adding the value in the 32-bit element pointer (r30) to the 7- or 8-bit displacement value contained in the instruction. This addressing mode applies to SLD and SST instructions. Figure 4-6. Based Addressing Byte access = disp7 Half-word access and word access = disp8 #### (4) Bit addressing This addressing is used to access 1 bit (specified with bit#3 of 3-bit data) among 1 byte of the memory space to be manipulated by using an operand address which is the sum of the contents of a general register and a 16-bit displacement sign-extended to a word length. This addressing mode applies only to bit manipulate instructions. 31 reg1 31 disp16 Memory to be manipulated Figure 4-7. Bit Addressing **Remark** n: Bit position specified with 3-bit data (bit#3) (n = 0 - 7) #### **CHAPTER 5 INSTRUCTION** #### 5.1 Instruction Format The V850 family has two types of instruction formats: 16-bit and 32-bit. The 16-bit instructions include binary operation, control, and conditional branch instructions, and the 32-bit instructions include load/store, jump, and instructions that handle 16-bit immediate data. Some instructions have an unused field (RFU). This field is reserved for future expansion and must be fixed to 0. An instruction is actually stored in memory as follows: - Lower bytes of instruction (including bit 0) → lower address - Higher bytes of instruction (including bit 15 or 31) → higher address #### (1) reg-reg instruction (Format I) A 16-bit instruction format having a 6-bit op code field and two general register specification fields for operand specification. #### (2) imm-reg instruction (Format II) A 16-bit instruction format having a 6-bit op code field, 5-bit immediate field, and a general register specification field. ### (3) Conditional branch instruction (Format III) A 16-bit instruction format having a 4-bit op code field, 4-bit condition code, and an 8-bit displacement. #### (4) 16-bit load/store instruction (Format IV) A 16-bit instruction format having a 4-bit op code field, a general register specification field, and a 7-bit displacement (or 6-bit displacement + 1-bit sub-op code). #### (5) Jump instruction (Format V) A 32-bit instruction format having a 5-bit op code field, a general register specification field, and a 22-bit displacement. ### (6) 3-operand instruction (Format VI) A 32-bit instruction format having a 6-bit op code field, two general register specification fields, and a 16-bit immediate field. #### (7) 32-bit load/store instruction (Format VII) A 32-bit instruction format having a 6-bit op code field, two general register specification fields, and a 16-bit displacement (or 15-bit displacement + 1-bit sub-op code). #### (8) Bit manipulation instruction (Format VIII) A 32-bit instruction format having a 6-bit op code field, 2-bit sub-op code, 3-bit bit specification field, a general register field, and a 16-bit displacement. #### (9) Extended instruction format 1 (Format IX) A 32-bit instruction format having a 6-bit op code field, 6-bit sub-op code, and two general register specification fields (one field may be regID or cond). ### (10) Extended instruction format 2 (Format X) A 32-bit instruction format having a 6-bit op code field and 6-bit sub op code. Remark RFU: Reserved field (Reserved for Future Use) ### 5.2 Outline of Instructions Load/store instructions ...... Transfer data from memory to a register or from a register to memory. Table 5-1. Load/Store Instructions | SLD | | |-----|--| | LD | | | SST | | | ST | | **Arithmetic operation instructions.....** Add, subtract, multiply, divide, transfer, or compare data between registers. Table 5-2. Arithmetic Operation Instructions | MOV | |-------| | MOVHI | | MOVEA | | ADD | | ADDI | | SUB | | SUBR | | MULH | | MULHI | | DIVH | | CMP | | SETF | Saturated operation instructions ...... Execute saturation addition or subtraction. If the result of the operation exceeds the maximum positive value (7FFFFFFH), 7FFFFFFH is returned. If the result exceeds the negative value (80000000H), 80000000H is returned. Table 5-3. Saturated Operation Instructions | SATADD | |---------| | SATSUB | | SATSUBI | | SATSUBR | Logical operation instructions ......... These instructions include logical operation instructions and shift instructions. The shift instructions include arithmetic shift and logical shift instructions. Operands can be shifted by two or more bit positions in one clock cycle by the universal barrel shifter. Table 5-4. Logical Operation Instructions | TST | | |------|--| | OR | | | ORI | | | AND | | | ANDI | | | XOR | | | XORI | | | NOT | | | SHL | | | SHR | | | SAR | | **Branch instructions** ...... Branch operations include unconditional branch along with conditional branch instructions which alter the flow of control, depending on the status of conditional flags in the PSW. Program control can be transferred to the address specified by a branch instruction. Table 5-5. Branch Instructions | JMP | |------| | JR | | JARL | | BGT | | BGE | | BLT | | BLE | | ВН | | BNL | | BL | | BNH | | BE | | BNE | | BV | | BNV | | BN | | ВР | | BC | | BNC | | BZ | | BNZ | | BR | | BSA | **Bit manipulation instructions......** Execute a logical operation to bit data in memory. Only a specified bit is affected as a result of executing a bit manipulation instruction. Table 5-6. Bit Manipulation Instructions | SET1 | |------| | CLR1 | | NOT1 | | TST1 | Table 5-7. Special Instructions | LDSR | | |------|--| | STSR | | | TRAP | | | RETI | | | HALT | | | DI | | | EI | | | NOP | | | | | ### 5.3 Instruction Set ### Example of instruction description # **Mnemonic of instruction** Meaning of instruction Instruction format Indicates the description and operand of the instruction. The following symbols are used in description of an operand: | Symbol | Meaning | | | |--------|------------------------------------------------------------------------------------------------|--|--| | reg1 | General register (used as source register) | | | | reg2 | General register (mainly used as destination register. Some are also used as source registers) | | | | bit#3 | 3-bit data for specification bit number | | | | imm× | ×-bit immediate | | | | disp× | ×-bit displacement | | | | regID | System register number | | | | vector | 5-bit data for trap vector (00H-1FH) specification | | | | cccc | 4-bit data for condition code specification | | | | ер | Element pointer (r30) | | | # Operation Describes the function of the instruction. The following symbols are used: | Symbol | Meaning | |-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------| | <b>←</b> | Assignment | | GR [] | General register | | SR [] | System register | | zero-extend (n) | Zero-extends n to word | | sign-extend (n) | Sign-extends n to word | | load-memory (a, b) | Reads data of size b from address a | | store-memory (a, b, c) | Writes data b of size c to address a | | load-memory-bit (a, b) | Reads bit b from address a | | store-memory-bit (a, b, c) | Writes c to bit b of address a | | saturated (n) | Performs saturation processing of n. If $n \ge 7FFFFFFFH$ as result of calculation, 7FFFFFFH. If $n \le 80000000H$ as result of calculation, 80000000H. | | result | Reflects result on flag | | Byte | Byte (8 bits) | | Halfword | Half-word (16 bits) | | Word | Word (32 bits) | | + | Add | | - | Subtract | | II | Bit concatenation | | × | Multiply | | ÷ | Divide | | AND | And | | OR | Or | | XOR | Exclusive Or | | NOT | Logical negate | | logically shift left by | Logical left shift | | logically shift right by | Logical right shift | | arithmetically shift right by | Arithmetic right shift | ### **Format** Indicates instruction format number. 33 #### Op code Describes the separate bit fields of the instruction opcode. The following symbols are used: | Symbol | Meaning | | | |--------|---------------------------------------------|--|--| | R | 1-bit data of code specifying reg1 or regID | | | | r | 1-bit data of code specifying reg2 | | | | d | 1-bit data of displacement | | | | i | 1-bit data of immediate | | | | cccc | 4-bit data for condition code specification | | | | bbb | 3-bit data for bit number specification | | | Flag Indicates the flags which are altered after executing the instruction. $\begin{array}{lll} \text{CY} & - & \leftarrow \text{Indicates that the flag is not affected.} \\ \text{OV} & 0 & \leftarrow \text{Indicates that the flag is cleared to 0.} \\ \text{S} & 1 & \leftarrow \text{Indicates that the flag is set to 1.} \\ \end{array}$ Z – SAT – Instruction Describes the function of the instruction. **Explanation** Explains the operation of the instruction. Remark Supplementary information on the instruction Caution Important cautions regarding use of this instruction ### **Instruction List** | Mnemonic | Function | Mnemonic | Function | |----------|------------------------------|----------|--------------------------------| | | Load/Store instructions | | Logical operation instructions | | SLD.B | Load Byte | TST | Test | | SLD.H | Load Half-word | OR | Or | | SLD.W | Load Word | ORI | Or Immediate | | LD.B | Load Byte | AND | And | | LD.H | Load Half-word | ANDI | And Immediate | | LD.W | Load Word | XOR | Exclusive-Or | | SST.B | Store Byte | XORI | Exclusive-Or Immediate | | SST.H | Store Half-word | NOT | Not | | SST.W | Store Word | SHL | Shift Logical Left | | ST.B | Store Byte | SHR | Shift Logical Right | | ST.H | Store Half-word | SAR | Shift Arithmetic Right | | ST.W | Store Word | | Branch instructions | | | Arithmetic instructions | JMP | Jump | | MOV | Move | JR | Jump Relative | | MOVHI | Move High half-word | JARL | Jump and Register Link | | MOVEA | Move Effective Address | Bcond | Branch on Condition Code | | ADD | Add | | Bit manipulation instructions | | ADDI | Add Immediate | SET1 | Set Bit | | SUB | Subtract | CLR1 | Clear Bit | | SUBR | Subtract Reverse | NOT1 | Not Bit | | MULH | Multiply Half-word | TST1 | Test Bit | | MULHI | Multiply Half-word Immediate | | Special instructions | | DIVH | Divide Half-word | LDSR | Load System Register | | CMP | Compare | STSR | Store System Register | | SETF | Set Flag Condition | TRAP | Trap | | | Saturate instructions | RETI | Return from Trap or Interrupt | | SATADD | Saturated Add | HALT | Halt | | SATSUB | Saturated Subtract | DI | Disable Interrupt | | SATSUBI | Saturated Subtract Immediate | EI | Enable Interrupt | | SATSUBR | Saturated Subtract Reverse | NOP | No Operation | # **ADD** Add Instruction format (1) ADD reg1, reg2 - (2) ADD imm5, reg2 Operation - (1) $GR [reg2] \leftarrow GR [reg2] + GR [reg1]$ - (2) GR [reg2] $\leftarrow$ GR [reg2] + sign-extend (imm5) **Format** - (1) Format I - (2) Format II Op code rrrrr010010iiiii Flag - CY 1 if a carry occurs from MSB; otherwise, 0. - OV 1 if Overflow occurs; otherwise, 0. - S 1 if the result of an operation is negative; otherwise, 0. - Ζ 1 if the result of an operation is 0; otherwise 0. SAT Instruction - (1) ADD Add Register - (2) ADD Add Immediate (5-bit) **Explanation** - (1) Adds the word data of general register reg1 to the word data of general register reg2, and stores the result to general register reg2. The data of general register reg1 is not affected. - (2) Adds 5-bit immediate data, sign-extended to word length, to the word data of general register reg2, and stores the result to general register reg2. # **ADDI** Flag **Add Immediate** Instruction format ADDI imm16, reg1, reg2 **Operation** GR [reg2] $\leftarrow$ GR [reg1] + sign-extend (imm16) Format VI CY 1 if a carry occurs from MSB; otherwise, 0. CY 1 if a carry occurs from MSB; otherwise, 0.OV 1 if Overflow occurs; otherwise, 0. S 1 if the result of an operation is negative; otherwise, 0. Z 1 if the result of an operation is 0; otherwise 0. SAT - Instruction ADDI Add immediate **Explanation** Adds 16-bit immediate data, sign-extended to word length, to the word data of general register reg1, and stores the result to general register reg2. The data of general register reg1 is not affected. **AND** And Instruction format AND reg1, reg2 **Operation** GR [reg2] $\leftarrow$ GR [reg2] AND GR [reg1] Format I **Op code** 15 0 rrrrr001010RRRRR Flag CY - OV ( S 1 if the result of an operation is negative; otherwise, 0. Z 1 if the result of an operation is 0; otherwise 0. SAT - Instruction AND And **Explanation** ANDs the word data of general register reg2 with the word data of general register reg1, and stores the result to general register reg2. The data of general register reg1 is not affected. # **ANDI** **And Immediate** Instruction format ANDI imm16, reg1, reg2 **Operation** GR [reg2] $\leftarrow$ GR [reg1] AND zero-extend (imm16) Format VI Flag CY – OV 0 S 0 Z 1 if the result of an operation is 0; otherwise 0. SAT - Instruction ANDI And Immediate (16-bit) **Explanation** ANDs the word data of general register reg1 with the value of the 16-bit immediate data, zero- extended to word length, and stores the result to general register reg2. The data of general register reg1 is not affected. # **Bcond** **Branch on Condition Code** Instruction format Boond disp9 **Operation** if conditions are satisfied then PC ← PC + sign-extend (disp9) Format III **Op code** 15 0 ddddd1011dddcccc ddddddd is the higher 8 bits of disp9. Flag CY - OV -S -Z -SAT - Instruction Boond Branch on Condition Code with 9-bit displacement **Explanation** Tests a condition flag specified by the instruction. Branches if a specified condition is satisfied; otherwise, executes the next instruction. The branch destination PC holds the sum of the current PC value and 9-bit displacement, which is 8-bit immediate shifted 1 bit and sign- extended to word length. Remark Bit 0 of the 9-bit displacement is masked to 0. The current PC value used for calculation is the address of the first byte of this instruction. If the displacement value is 0, therefore, the branch destination is this instruction itself. Table 5-8. Conditional Branch Instructions | Instru | ction | Condition Code (cccc) | Status of Condition Flag | Branch Condition | |----------|-------|-----------------------|-------------------------------------|-----------------------------------| | Signed | BGT | 1111 | ( (S xor OV) or Z) = 0 | Greater than signed | | integer | BGE | 1110 | (S xor OV) = 0 | Greater than or equal signed | | | BLT | 0110 | (S xor OV) = 1 | Less than signed | | | BLE | 0111 | $((S \times OV) \text{ or } Z) = 1$ | Less than or equal signed | | Unsigned | ВН | 1011 | (CY or Z) = 0 | Higher (Greater than) | | integer | BNL | 1001 | CY = 0 | Not lower (Greater than or equal) | | | BL | 0001 | CY = 1 | Lower (Less than) | | | BNH | 0011 | (CY or Z) = 1 | Not higher (Less than or equal) | | Common | BE | 0010 | Z = 1 | Equal | | | BNE | 1010 | Z = 0 | Not equal | | Others | BV | 0000 | OV = 1 | Overflow | | | BNV | 1000 | OV = 0 | No overflow | | | BN | 0100 | S = 1 | Negative | | | BP | 1100 | S = 0 | Positive | | | вс | 0001 | CY = 1 | Carry | | | BNC | 1001 | CY = 0 | No carry | | | BZ | 0010 | Z = 1 | Zero | | | BNZ | 1010 | Z = 0 | Not zero | | | BR | 0101 | _ | Always (unconditional) | | | BSA | 1101 | SAT = 1 | Saturated | #### Caution If executing a conditional branch instruction of a signed integer (BGT, BGE, BLT, or BLE) when the SAT flag is set to 1 as a result of executing a saturated operation instruction, the branch condition loses its meaning. In ordinary arithmetic operations, if an overflow condition occurs, the S flag is inverted ( $0 \rightarrow 1$ or $1 \rightarrow 0$ ). This is because the result is a negative value if it exceeds the maximum positive value and it is a positive value if it exceeds the maximum negative value. However, when a saturated operation instruction is executed, and if the result exceeds the maximum positive value, the result is saturated with a positive value; if the result exceeds the maximum negative value, the result is saturated with a negative value. Unlike the ordinary operation, therefore, the S flag is not inverted even if an overflow occurs. Hence, the S flag of the PSW is affected differently when the instruction is a saturate operation, as opposed to an ordinary arithmetic operation. A branch condition which is an XOR of S and OV flags will therefore, have no meaning. # CLR<sub>1</sub> Clear Bit Instruction format CLR1 bit#3, disp16 [reg1] **Operation** $adr \leftarrow GR [reg1] + sign-extend (disp16)$ $Z flag \leftarrow Not (Load-memory-bit (adr, bit#3))$ Store-memory-bit (adr, bit#3, 0) Format VIII **Op code** 15 0 31 16 10bbb111110RRRRR ddddddddddddddd Flag CY - OV - S · Z 1 if bit NO.bit#3 of memory disp16 [reg1] = 0. 0 if bit NO.bit#3 of memory disp16 [reg1] = 1. SAT - Instruction CLR1 Clear Bit **Explanation** Adds the data of general register reg1 to the 16-bit displacement, sign-extended to word length, to generate a 32-bit address. Then clears the bit, specified by the bit number of 3 bits, of the byte data referenced by the generated address. Not specified bit is not affected. Remark The Z flag of the PSW indicates whether the specified bit was a 0 or 1 before this instruction is executed. It does not indicate the content of the specified bit after this instruction has been executed. ## **CMP** Compare Instruction format (1) CMP reg1, reg2 - (2) CMP imm5, reg2 Operation - (1) result $\leftarrow$ GR [reg2] GR [reg1] - (2) result ← GR [reg2] sign-extend (imm5) **Format** - (1) Format I - (2) Format II Op code Flag - CY 1 if a borrow to MSB occurs; otherwise, 0. - OV 1 Overflow occurs; otherwise 0. - S 1 if the result of the operation is negative; otherwise, 0. - Ζ 1 if the result of the operation is 0; otherwise, 0. SAT Instruction - (1) CMP Compare Register - (2) CMP Compare Immediate (5-bit) #### **Explanation** - (1) Compares the word data of general register reg2 with the word data of general register reg1, and indicates the result by using the condition flags. To compare, the contents of general register reg1 are subtracted from the word data of general register reg2. The data of general registers reg1 and reg2 are not affected. - (2) Compares the word data of general register reg2 with 5-bit immediate data, sign-extended to word length, and indicates the result by using the condition flags. To compare, the contents of the sign-extended immediate data is subtracted from the word data of general register reg2. The data of general register reg2 is not affected. DI **Disable Interrupt** Instruction format DI **Operation** PSW.ID ← 1 (Disables maskable interrupt) Format X Op code 15 0 31 16 00000111111100000 0000000101100000 Flag CY - OV -S -Z -SAT -ID 1 Instruction DI Disable Interrupt **Explanation** Sets the ID flag of the PSW to 1 to disable the acknowledgement of maskable interrupts during executing this instruction. **Remark** Interrupts are not sampled during execution of this instruction. The ID flag actually becomes valid at the start of the next instruction. But because interrupts are not sampled during instruction execution, interrupts are immediately disabled. Non-maskable interrupts are not affected by this instruction. ### **DIVH** **Divide Half-word** Instruction format DIVH reg1, reg2 **Operation** $GR [reg2] \leftarrow GR [reg2] \div GR [reg1]$ Format I Op code 15 rrrr000010RRRRR Flag CY - OV 1 if Overflow occurs; otherwise, 0. S 1 if the result of an operation is negative; otherwise, 0. Z 1 if the result of an operation is 0; otherwise, 0. SAT - Instruction DIVH Divide Half-word **Explanation** Divides the word data of general register reg2 by the lower half-word data of general register reg1, and stores the quotient to general register reg2. If the data is divided by 0, Overflow occurs, and the quotient is undefined. The data of general register reg1 is not affected. Remark The remainder is not stored. Overflow occurs when the maximum negative value (80000000H) is divided by -1 (in which case the quotient is 80000000H) and when data is divided by 0 (in which case the quotient is undefined). If an interrupt occurs while this instruction is executed, division is aborted, and the interrupt is processed. Upon returning from the interrupt, the division is restarted from the beginning, with the return address being the address of this instruction. Also, general registers reg1 and reg2 will retain their original values prior to the start of execution. The higher 16 bits of general register reg1 are ignored when division is executed. ΕI **Enable Interrupt** Instruction format El **Operation** PSW.ID $\leftarrow$ 0 (enables maskable interrupt) Format X Op code 15 0 31 16 10000111111100000 0000000101100000 0 Flag CY - OV – S – Z – SAT – ID 0 Instruction El Enable Interrupt **Explanation** Resets the ID flag of the PSW to 0 and enables the acknowledgement of maskable interrupts beginning at the next instruction. **Remark** Interrupts are not sampled during instruction execution. # **HALT** Halt Instruction format HALT Operation. Halts Format X Op code 15 0 31 16 00000111111100000 00000001001000000 Flag CY - OV – S – Z – SAT – Instruction HALT Halt **Explanation** Stops the operating clock of the CPU and places the CPU in the HALT mode. **Remark** The HALT mode is exited by any of the following three events: • RESET input • NMI input • Maskable interrupt (when ID of PSW = 0) If an interrupt is acknowledged during the HALT mode, the address of the following instruction is stored to EIPC or FEPC. ## **JARL** Jump and Register Link Instruction format JARL disp22, reg2 **Operation** GR [reg2] $\leftarrow$ PC + 4 $PC \leftarrow PC + sign-extend (disp22)$ Format V **Op code** 15 0 31 16 rrrrlllll0dddddd ddddddddddddddd0 dddddddddddddddddd is the higher 21 bits of disp22. Flag CY - OV – S – Z – SAT – Instruction JARL Jump and Register Link **Explanation** Saves the current PC value plus 4 to general register reg2, adds the current PC value and 22- bit displacement, sign-extended to word length, and transfers control to that PC. Bit 0 of the 22-bit displacement is masked to 0. Remark The current PC value used for calculation is the address of the first byte of this instruction. If the displacement value is 0, the branch destination is this instruction itself. This instruction is equivalent to a call subroutine instruction, and saves the PC return address to general register reg2. The JMP instruction, which is equivalent to a subroutine-return instruction, can be used to specify the general register containing the return address saved during the JARL subroutine-call instruction, to restore the program counter. # **JMP** Jump Register Instruction format JMP [reg1] **Operation** $PC \leftarrow GR [reg1]$ Format I **Op code** 15 0 0000000011RRRRR Flag CY - OV – S – Z – SAT – **Instruction** JMP Jump Register **Explanation** Transfers control to the address specified by general register reg1. Bit 0 of the address is masked to 0. Remark When using this instruction as the subroutine-return instruction, specify the general register containing the return address saved during the JARL subroutine-call instruction, to restore the program counter. When using the JARL instruction, which is equivalent to the subroutine-call instruction, store the PC return address in general register reg2. JR Jump Relative Instruction format JR disp22 **Operation** $PC \leftarrow PC + sign-extend (disp22)$ Format V dddddddddddddddddd is the higher 21 bits of disp22. Flag CY - OV – S – Z – SAT - **Instruction** JR Jump Relative **Explanation** Adds the 22-bit displacement, sign-extended to word length, to the current PC value and stores the value in the PC, and then transfers control to that PC. Bit 0 of the 22-bit displacement is masked to 0. **Remark** The current PC value used for the calculation is the address of the first byte of this instruction itself. Therefore, if the displacement value is 0, the jump destination is this instruction. LD Load - Instruction format (1) LD.B disp16 [reg1], reg2 - (2) LD.H disp16 [reg1], reg2 - (3) LD.W disp16 [reg1], reg2 Operation - (1) $adr \leftarrow GR [reg1] + sign-extend (disp16)$ GR [reg2] ← sign-extend (Load-memory (adr, Byte)) - (2) adr ← GR [reg1] + sign-extend (disp16) GR [reg2] ← sign-extend (Load-memory (adr, Halfword)) - (3) adr ← GR [reg1] + sign-extend (disp16) GR [reg2] ← Load-memory (adr, Word) **Format** Format VII Op code ddddddddddddd is the higher 15 bits of disp16. ddddddddddddd is the higher 15 bits of disp16. Flag CY OV S Ζ SAT Instruction - (1) LD.B Load Byte - (2) LD.H Load Half-word - (3) LD.W Load Word #### **Explanation** - (1) Adds the data of general register reg1 to a 16-bit displacement, sign-extended to word length, to generate a 32-bit address. Byte data is read from the generated address, sign-extended to word length, and then stored to general register reg2. - (2) Adds the data of general register reg1 to a 16-bit displacement sign-extended to word length to generate a 32-bit address. Half-word data is read from this 32-bit address with its bit 0 masked to 0, sign-extended to word length, and stored to general register reg2. - (3) Adds the data of general register reg1 to a 16-bit displacement sign-extended to word length to generate a 32-bit address. Word data is read from this 32-bit address with bits 0 and 1 masked to 0, and stored to general register reg2. #### Caution When the data of general register reg1 is added to a 16-bit displacement sign-extended to word length, the lower bits of the result may be masked to 0 depending on the type of data to be accessed (half word, word) to generate an address. ## **LDSR** Load to System Register Instruction format LDSR reg2, regID **Operation** SR [regID] $\leftarrow$ GR [reg2] Format IX Op code 15 0 31 16 **Remark** The fields used to define reg1 and reg2 are swapped in this instruction. Normally, "RRR" is used for reg1 and is the source operand while "rrr" signifies reg2 and is the destination operand. In this instruction, "RRR" is still the source operand, but is represented by reg2, while "rrr" is the special register destination, as labeled below: rrrrr: regID specification RRRRR: reg2 specification Flag CY – (Refer to Remark below.) OV - (Refer to Remark below.) S - (Refer to Remark below.) Z - (Refer to Remark below.) SAT - (Refer to Remark below.) Instruction LDSR Load to System Register **Explanation** Loads the word data of general register reg2 to a system register specified by the system register number (regID). The data of general register reg2 is not affected. Remark If the system register number (regID) is equal to 5 (PSW register), the values of the corresponding bits of the PSW are set according to the contents of reg2. This only affects the flag bits, the reserved bits remain at 0. Also, interrupts are not sampled when the PSW is being written with a new value. If the ID flag is enabled with this instruction, interrupt disabling begins at the start of execution, even though the ID flag does not become valid until the beginning of the next instruction. Caution The system register number regID is a number which identifies a system register. Accessing system registers which are reserved or write-prohibited is prohibited and will lead to undefined results. # MOV Move Instruction format (1) MOV reg1, reg2 (2) MOV imm5, reg2 Operation - (1) $GR [reg2] \leftarrow GR [reg1]$ - (2) GR [reg2] $\leftarrow$ sign-extend (imm5) **Format** - (1) Format I - (2) Format II Op code Flag CY OV S Ζ SAT Instruction - (1) MOV Move Register - (2) MOV Move Immediate (5-bit) #### **Explanation** - (1) Transfers the word data of general register reg1 to general register reg2. The data of general register reg1 is not affected. - (2) Transfers the value of a 5-bit immediate data, sign-extended to word length, to general register reg2. # **MOVEA** **Moves Effective Address** Instruction format MOVEA imm16, reg1, reg2 **Operation** GR [reg2] $\leftarrow$ GR [reg1] + sign-extend (imm16) Format VI **Op code** 15 0 31 16 rrrr110001RRRRR iiiiiiiiiiiiiiiii Flag CY - OV – S – Z – SAT – Instruction MOVEA Move Effective Address **Explanation** Adds the 16-bit immediate data, sign-extended to word length, to the word data of general register reg1, and stores the result to general register reg2. The data of general register reg1 is not affected. The flags are not affected by the addition. Remark This instruction calculates a 32-bit address and stores the result without affecting the PSW flags. # **MOVHI** Move High half-word Instruction format MOVHI imm16, reg1, reg2 **Operation** GR [reg2] $\leftarrow$ GR [reg1] + (imm16 II $0^{16}$ ) Format VI Flag CY - OV – S – Z – SAT – Instruction MOVHI Move High half-word **Explanation** Adds a word value, whose higher 16 bits are specified by the 16-bit immediate data and lower 16 bits are 0, to the word data of general register reg1 and stores the result in general register reg2. The data of general register reg1 is not affected. The flags are not affected by the addition. **Remark** This instruction is used to generate the high 16 bits of a 32-bit address. ## **MULH** **Multiply Half-word** Instruction format (1) MULH reg1, reg2 (2) MULH imm5, reg2 **Operation** (1) GR [reg2] (32) $\leftarrow$ GR [reg2] (16) $\times$ GR [reg1] (16) (2) GR [reg2] $\leftarrow$ GR [reg2] $\times$ sign-extend (imm5) Format (1) Format I (2) Format II Op code 15 0 (1) rrrrr000111RRRRR 15 0 (2) rrrrr010111iiiii Flag CY – S -Z - SAT - Instruction - (1) MULH Multiply Half-word by Register - (2) MULH Multiply Half-word by Immediate (5-bit) **Explanation** - (1) Multiplies the lower half-word data of general register reg2 by the half-word data of general register reg1, and stores the result to general register reg2 as word data. The data of general register reg1 is not affected. - (2) Multiplies the lower half-word data of general register reg2 by a 5-bit immediate data, sign-extended to half-word length, and stores the result to general register reg2. Remark The higher 16 bits of general registers reg1 and reg2 are ignored in this operation. # **MULHI** **Multiply Half-word Immediate** Instruction format MULHI imm16, reg1, reg2 $\textbf{Operation} \qquad \qquad \mathsf{GR} \; [\mathsf{reg2}] \leftarrow \mathsf{GR} \; [\mathsf{reg1}] \times \mathsf{imm16}$ Format VI Flag CY - OV – S – Z – SAT – Instruction MULHI Multiply Half-word by immediate (16-bit) **Explanation** Multiplies the lower half-word data of general register reg1 by the 16-bit immediate data, and stores the result to general register reg2. The data of general register reg1 is not affected. **Remark** The higher 16 bits of general register reg1 are ignored in this operation. # **NOP** No Operation Instruction format NOP **Operation** Executes nothing and consumes at least one clock. Format I Op code 15 0000000000000000 Flag CY - OV – S – Z – SAT – **Instruction** NOP No Operation **Explanation** Executes nothing and consumes at least one clock cycle. **Remark** The contents of the PC are incremented by two. The op code is the same as that of MOV r0, r0. **NOT** Not Instruction format NOT reg1, reg2 **Operation** GR [reg2] $\leftarrow$ NOT (GR [reg1]) Format I Op code 15 0 rrrrr000001RRRRR Flag CY - OV S 1 if the result of an operation is negative; otherwise, 0. Z 1 if the result of an operation is 0; otherwise, 0. SAT - Instruction NOT Not **Explanation** Logically negates (takes the 1's complement of) the word data of general register reg1, and stores the result to general register reg2. The data of general register reg1 is not affected. # NOT1 **Not Bit** Instruction format NOT1 bit#3, disp16 [reg1] **Operation** $adr \leftarrow GR [reg1] + sign-extend (disp16)$ $Z flag \leftarrow Not (Load-memory-bit (adr, bit#3))$ Store-memory-bit (adr, bit#3, Z flag) Format VIII **Op code** 15 0 31 16 01bbb111110RRRRR ddddddddddddddd Flag CY - OV -S - Z 1 if bit NO.bit#3 of memory disp16 [reg1] = 0. 0 if bit NO.bit#3 of memory disp16 [reg1] = 1. SAT - Instruction NOT1 Not Bit **Explanation** Adds the data of general register reg1 to a 16-bit displacement, sign-extended to word length to generate a 32-bit address. The bit, specified by the 3-bit field "bbb", is inverted at the byte data location referenced by the generated address. The bits other than the specified bit are not affected. Remark The Z flag of the PSW indicates whether the specified bit was 0 or 1 before this instruction is executed, and does not indicate the content of the specified bit after this instruction has been executed. **OR** Or Instruction format OR reg1, reg2 **Operation** GR [reg2] $\leftarrow$ GR [reg2] OR GR [reg1] Format I Op code 15 0 rrrrr001000RRRRR Flag CY - OV ( S 1 if the result of an operation is negative; otherwise, 0. Z 1 if the result of an operation is 0; otherwise, 0. SAT - **Instruction** OR Or **Explanation** ORs the word data of general register reg2 with the word data of general register reg1, and stores the result to general register reg2. The data of general register reg1 is not affected. **ORI** Or Immediate Instruction format ORI imm16, reg1, reg2 **Operation** GR [reg2] $\leftarrow$ GR [reg1] OR zero-extend (imm16) Format VI Flag CY - OV 0 S 1 if the result of an operation is negative; otherwise, 0. Z 1 if the result of an operation is 0; otherwise, 0. SAT - Instruction OR Or immediate (16-bit) **Explanation** ORs the word data of general register reg1 with the value of the 16-bit immediate data, zero- extended to word length, and stores the result to general register reg2. The data of general register reg1 is not affected. # **RETI** **Return from Trap or Interrupt** ## Instruction format RETI #### Operation ``` \begin{array}{ll} \text{if PSW.EP} = 1 \\ \text{then PC} & \leftarrow \text{EIPC} \\ \text{PSW} \leftarrow \text{EIPSW} \\ \text{else} & \text{if PSW.NP} = 1 \\ \text{then PC} & \leftarrow \text{FEPC} \\ \text{PSW} \leftarrow \text{FEPSW} \\ \text{else} & \text{PC} & \leftarrow \text{EIPC} \\ \text{PSW} \leftarrow \text{EIPSW} \end{array} ``` Format Format X Op code | 15 0 | 31 16 | |------------------|------------------| | 0000011111100000 | 0000000101000000 | #### Flag CY Value read from FEPSW or EIPSW is restored. OV Value read from FEPSW or EIPSW is restored. S Value read from FEPSW or EIPSW is restored. Z Value read from FEPSW or EIPSW is restored. SAT Value read from FEPSW or EIPSW is restored. ## Instruction RETI Return from Trap or Interrupt ## **Explanation** This instruction restores the return PC and PSW from the appropriate system register and returns from an exception or interrupt routine. The operations of this instruction are as follows: - (1) If the EP flag of the PSW is 1, the return PC and PSW are read from the EIPC and EIPSW, regardless of the status of the NP flag of the PSW. - If the EP flag of the PSW is 0 and the NP flag of the PSW is 1, the return PC and PSW are read from the FEPC and FEPSW. - If the EP flag of the PSW is 0 and the NP flag of the PSW is 0, the return PC and PSW are read from the EIPC and EIPSW. - (2) Once the PC and PSW are restored to the return values, control is transferred to the return address. #### Caution When returning from an NMI or exception routine using the RETI instruction, the PSW.NP and PSW.EP flags must be set accordingly to restore the PC and PSW: • When returning from non-maskable interrupt routine using the RETI instruction: • When returning from an exception routine using the RETI instruction: $$PSW.EP = 1$$ Use the LDSR instruction for setting the flags. All interrupts are not accepted in the latter half of the ID stage during LDSR execution because of the operation of the interrupt controller. # SAR **Shift Arithmetic Right** Instruction format (1) SAR reg1, reg2 - (2) SAR imm5, reg2 Operation - (1) GR [reg2] ← GR [reg2] arithmetically shift right by GR [reg1] - (2) GR [reg2] ← GR [reg2] arithmetically shift right by zero-extend **Format** - (1) Format IX - (2) Format II Op code Flag - CY 1 if the bit shifted out last is 1; otherwise, 0. - However, if the number of shifts is 0, the result is 0. - OV - S 1 if the result of an operation is negative; otherwise, 0. - Ζ 1 if the result of an operation is 0; otherwise, 0. - SAT Instruction - (1) SAR Shift Arithmetic Right by Register - (2) SAR Shift Arithmetic Right by Immediate (5-bit) ## **Explanation** - (1) Arithmetically shifts the word data of general register reg2 to the right by 'n' positions, where 'n' is a value from 0 to +31, specified by the lower 5 bits of general register reg1 (after the shift, the MSB prior to shift execution is copied and set as the new MSB value), and then writes the result to general register reg2. If the number of shifts is 0, general register reg2 retains the same value prior to instruction execution. The data of general register reg1 is not affected. - (2) Arithmetically shifts the word data of general register reg2 to the right by 'n' positions, where 'n' is a value from 0 to +31, specified by the 5-bit immediate data, zero-extended to word length (after the shift, the MSB prior to shift execution is copied and set as the new MSB value), and then writes the result to general register reg2. If the number of shifts is 0, general register reg2 retains the same value prior to instruction execution. # SATADD Saturated Add Instruction format (1) SATADD reg1, reg2 (2) SATADD imm5, reg2 **Operation** (1) GR [reg2] $\leftarrow$ saturated (GR [reg2] + GR [reg1]) (2) GR [reg2] ← saturated (GR [reg2] + sign-extend (imm5)) Format (1) Format I (2) Format II Op code 15 0 (1) rrrrr000110RRRRR 15 0 (2) rrrrr010001iiiii Flag CY 1 if a carry occurs from MSB; otherwise, 0. OV 1 if Overflow occurs; otherwise, 0. S 1 if the result of the saturated operation is negative; otherwise, 0. Z 1 if the result of the saturated operation is 0; otherwise, 0. SAT 1 if OV = 1; otherwise, not affected. Instruction (1) SATADD Saturated add register (2) SATADD Saturated add Immediate (5-bit) #### **Explanation** - (1) Adds the word data of general register reg1 to the word data of general register reg2, and stores the result to general register reg2. However, if the result exceeds the maximum positive value 7FFFFFFH, 7FFFFFFH is stored to reg2; if the result exceeds the maximum negative value 80000000H, 80000000H is stored to reg2. The SAT flag is set to 1. The data of general register reg1 is not affected. - (2) Adds a 5-bit immediate data, sign-extended to word length, to the word data of general register reg2, and stores the result to general register reg2. However, if the result exceeds the maximum positive value 7FFFFFFH, 7FFFFFFH is stored to reg2; if the result exceeds the maximum negative value 80000000H, 80000000H is stored to reg2. The SAT flag is set to 1. ## Remark The SAT flag is a cumulative flag. Once the result of the saturated operation instruction has been saturated, this flag is set to 1 and is not reset to 0 even if the result of the subsequent operation is not saturated. Even if the SAT flag is set to 1, the saturated operation instruction is executed normally. Caution To reset the SAT flag to 0, load data to the PSW by using the LDSR instruction. 67 . # **SATSUB** Saturated Subtract Instruction format SATSUB reg1, reg2 **Operation** $GR [reg2] \leftarrow saturated (GR [reg2] - GR [reg1])$ Format I Op code 15 0 rrrrr000101RRRRR Flag CY 1 if a borrow to MSB occurs; otherwise, 0. OV 1 if Overflow occurs; otherwise, 0. S 1 if the result of the saturated operation is negative; otherwise, 0. Z 1 if the result of the saturated operation is 0; otherwise, 0. SAT 1 if OV = 1; otherwise, not affected. Instruction SATSUB Saturated Subtract **Explanation** Subtracts the word data of general register reg1 from the word data of general register reg2, and stores the result to general register reg2. However, if the result exceeds the maximum positive value 7FFFFFFH, 7FFFFFFH is stored to reg2; if the result exceeds the maximum negative value 80000000H, 80000000H is stored to reg2. The SAT flag is set to 1. The data of general register reg1 is not affected. **Remark** The SAT flag is a cumulative flag. Once the result of the operation of the saturated operation instruction has been saturated, this flag is set to 1 and is not reset to 0 even if the result of the subsequent operations is not saturated. ★ Even if the SAT flag is set to 1, the saturated operation instruction is executed normally. **Caution** To reset the SAT flag to 0, load data to the PSW by using the LDSR instruction. # **SATSUBI** Saturated Subtract Immediate Instruction format SATSUBI imm16, reg1, reg2 **Operation** GR [reg2] ← saturated (GR [reg1] – sign-extend (imm16)) Format VI **Op code** 15 0 31 16 rrrr110011RRRRR iiiiiiiiiiiiiiii Flag CY 1 if a borrow to MSB occurs; otherwise, 0. OV 1 if Overflow occurs; otherwise, 0. S 1 if the result of the saturated operation is negative; otherwise, 0. Z 1 if the result of the saturated operation is 0; otherwise, 0. SAT 1 if OV = 1; otherwise, not affected. Instruction SATSUBI Saturated Subtract Immediate **Explanation** Subtracts the 16-bit immediate data, sign-extended to word length, from the word data of general register reg1, and stores the result to general register reg2. However, if the result exceeds the maximum positive value 7FFFFFFH, 7FFFFFFH is stored to reg2; if the result exceeds the maximum negative value 80000000H, 80000000H is stored to reg2. The SAT flag is set to 1. The data of general register reg1 is not affected. **Remark** The SAT flag is a cumulative flag. Once the result of the operation of the saturated operation instruction has been saturated, this flag is set to 1 and is not reset to 0 even if the result of the subsequent operations is not saturated. Even if the SAT flag is set to 1, the saturated operation instruction is executed normally. **Caution** To reset the SAT flag to 0, load data to the PSW by using the LDSR instruction. # SATSUBR **Saturated Subtract Reverse** Instruction format SATSUBR reg1, reg2 **Operation** $GR [reg2] \leftarrow saturated (GR [reg1] - GR [reg2])$ Format I Op code 15 0 rrrrr000100RRRRR Flag CY 1 if a borrow to MSB occurs; otherwise, 0. OV 1 if Overflow occurs; otherwise, 0. S 1 if the result of the saturated operation is negative; otherwise, 0. Z 1 if the result of the saturated operation is 0; otherwise, 0. SAT 1 if OV = 1; otherwise, not affected. Instruction SATSUBR Saturated Subtract Reverse **Explanation** Subtracts the word data of general register reg2 from the word data of general register reg1, and stores the result to general register reg2. However, if the result exceeds the maximum positive value 7FFFFFFH, 7FFFFFFH is stored to reg2; if the result exceeds the maximum negative value 80000000H, 80000000H is stored to reg2. The SAT flag is set to 1. The data of general register reg1 is not affected. **Remark** The SAT flag is a cumulative flag. Once the result of the operation of the saturated operation instruction has been saturated, this flag is set to 1 and is not reset to 0 even if the result of the subsequent operations is not saturated. ★ Even if the SAT flag is set to 1, the saturated operation instruction is executed normally. **Caution** To reset the SAT flag to 0, load data to the PSW by using the LDSR instruction. # **SETF** **Set Flag Condition** Instruction format SETF cccc, reg2 **Operation** if conditions are satisfied then GR [reg2] $\leftarrow$ 00000001H else GR [reg2] $\leftarrow$ 00000000H Format IX **Op code** 15 0 31 16 rrrr1111110cccc 00000000000000000 Flag CY - OV – S – Z – SAT – Instruction SETF Set Flag Condition **Explanation** The general register reg2 is set to 1 if a condition specified by condition code "cccc" is satisfied; otherwise, 0 are stored to the register. One of the codes shown in Table 5-9 should be specified as the condition code "cccc". ## Remark Here are some examples of using this instruction: - (1) Translation of two or more condition clauses: If A of statement if (A) in C language consists of two or more condition clauses (a<sub>1</sub>, a<sub>2</sub>, a<sub>3</sub>, and so on), it is usually translated to a sequence of if (a<sub>1</sub>) then, if (a<sub>2</sub>) then. The object code executes "conditional branch" by checking the result of evaluation equivalent to a<sub>n</sub>. A pipeline processor takes more time to execute "condition judgment" + "branch" than to execute an ordinary operation, the result of evaluating each condition clause if (a<sub>n</sub>) is stored to register Ra. By performing a logical operation to Ra<sub>n</sub> after all the condition clauses have been evaluated, the delay due to the pipeline can be prevented. - (2) Double-length operation: To execute a double-length operation such as Add with Carry, the result of the CY flag can be stored to general register reg2. Therefore, a carry from the lower bits can be expressed as a numeric value. Table 5-9. Condition Codes | Condition Code (cccc) | Condition Name | Condition Expression | |-----------------------|----------------|-----------------------| | 0000 | V | OV = 1 | | 1000 | NV | OV = 0 | | 0001 | C/L | CY = 1 | | 1001 | NC/NL | CY = 0 | | 0010 | Z | Z = 1 | | 1010 | NZ | Z = 0 | | 0011 | NH | (CY or Z) = 1 | | 1011 | н | (CY or Z) = 0 | | 0100 | S/N | S = 1 | | 1100 | NS/P | S = 0 | | 0101 | Т | always | | 1101 | SA | SAT = 1 | | 0110 | LT | (S xor OV) = 1 | | 1110 | GE | (S xor OV) = 0 | | 0111 | LE | ((S xor OV) or Z) = 1 | | 1111 | GT | ((S xor OV) or Z) = 0 | # SET1 Set Bit Instruction format SET1 bit#3, disp16 [reg1] **Operation** adr ← GR [reg1] + sign-extend (disp16) $Z flag \leftarrow Not (Load-memory-bit (adr, bit#3))$ Store-memory-bit (adr, bit#3, 1) Format VIII **Op code** 15 0 31 16 00bbb111110RRRRR ddddddddddddddd Flag CY - OV -S - Z 1 when bit NO.bit#3 of memory disp16 [reg1] = 0. 0 when bit NO.bit#3 of memory disp16 [reg1] = 1 SAT - Instruction SET1 Set Bit **Explanation** Adds the 16-bit displacement, sign-extended to word length, to the data of general register reg1 to generate a 32-bit address. The bit, specified by the 3-bit field "bbb", is set at the byte data location referenced by the generated address. The bits other than the specified bit are not affected. Remark The Z flag of the PSW indicates whether the specified bit was 0 or 1 before this instruction is executed, and does not indicate the content of the specified bit after this instruction has been executed. # SHL Shift Logical Left Instruction format (1) SHL reg1, reg2 - (2) SHL imm5, reg2 Operation - (1) GR [reg2] ← GR [reg2] logically shift left by GR [reg1] - (2) GR [reg2] ← GR [reg2] logically shift left by zero-extend (imm5) **Format** - (1) Format IX - (2) Format II Op code Flag - CY 1 if the bit shifted out last is 1; otherwise, 0. - However, if the number of shifts is 0, the result is 0. - OV - S 1 if the result of an operation is negative; otherwise, 0. - Ζ 1 if the result of an operation is 0; otherwise, 0. - SAT Instruction - (1) SHL Shift Logical Left by Register - (2) SHL Shift Logical Left by Immediate (5-bit) ## **Explanation** - (1) Logically shifts the word data of general register reg2 to the left by 'n' positions, where 'n' is a value from 0 to +31, specified by the lower 5 bits of general register reg1 (0 is shifted to the LSB side), and then writes the result to general register reg2. If the number of shifts is 0, general register reg2 retains the same value prior to instruction execution. The data of general register reg1 is not affected. - (2) Logically shifts the word data of general register reg2 to the left by 'n' positions, where 'n' is a value from 0 to +31, specified by the 5-bit immediate data, zero-extended to word length (0 is shifted to the LSB side), and then writes the result to general register reg2. If the number of shifts is 0, general register reg2 retains the value prior to instruction execution. # SHR Shift Logical Right Instruction format (1) SHR reg1, reg2 (2) SHR imm5, reg2 Operation (1) GR [reg2] $\leftarrow$ GR [reg2] logically shift right by GR [reg1] (2) GR [reg2] ← GR [reg2] logically shift right by zero-extend (imm5) Format (1) Format IX (2) Format II Op code Flag CY 1 if the bit shifted out last is 1; otherwise, 0. However, if the number of shifts is 0,the result is 0. OV 0 S 1 if the result of an operation is negative; otherwise, 0. Z 1 if the result of an operation is 0; otherwise, 0. SAT - Instruction - (1) SHR Shift Logical Right by Register - (2) SHR Shift Logical Right by Immediate (5-bit) ## **Explanation** - (1) Logically shifts the word data of general register reg2 to the right by 'n' positions where 'n' is a value from 0 to +31, specified by the lower 5 bits of general register reg1 (0 is shifted to the MSB side). This instruction then writes the result to general register reg2. If the number of shifts is 0, general register reg2 retains the same value prior to instruction execution. The data of general register reg1 is not affected. - (2) Logically shifts the word data of general register reg2 to the right by 'n' positions, where 'n' is a value from 0 to +31, specified by the 5-bit immediate data, zero-extended to word length (0 is shifted to the MSB side). This instruction then writes the result to general register reg2. If the number of shifts is 0, general register reg2 retains the same value prior to instruction execution. # **SLD** Load - Instruction format (1) SLD.B disp7 [ep], reg2 - (2) SLD.H disp8 [ep], reg2 - (3) SLD.W disp8 [ep], reg2 ## Operation (1) $adr \leftarrow ep + zero-extend (disp7)$ GR [reg2] ← sign-extend (Load-memory (adr, Byte)) (2) $adr \leftarrow ep + zero-extend (disp8)$ GR [reg2] ← sign-extend (Load-memory (adr, Halfword)) (2) $adr \leftarrow ep + zero-extend (disp8)$ GR [reg2] ← Load-memory (adr, Word) ## **Format** Format IV ## Op code ddddddd is the higher 7 bits of disp8. dddddd is the higher 6 bits of disp8. ## Flag CY OV S Ζ SAT ## Instruction - (1) SLD.B Short format Load Byte - (2) SLD.H Short format Load Half-word - (3) SLD.W Short format Load Word ## **Explanation** - (1) Adds the 7-bit displacement, zero-extended to word length, to the element pointer to generate a 32-bit address. Byte data is read from the generated address, sign-extended to word length, and stored to reg2. - (2) Adds the 8-bit displacement, zero-extended to word length, to the element pointer to generate a 32-bit address. Half-word data is read from this 32-bit address with bit 0 masked to 0, sign-extended to word length, and stored to reg2. - (3) Adds the 8-bit displacement, zero-extended to word length, to the element pointer to generate a 32-bit address. Word data is read from this 32-bit address with bits 0 and 1 masked to 0, and stored to reg2. ## Caution When the element pointer is added to the 8-bit displacement zero extended to word length, the lower bits of the result may be masked to 0 depending on the type of data to be accessed (half word, word). # **SST** **Short Store** - Instruction format (1) SST.B reg2, disp7 [ep] - (2) SST.H reg2, disp8 [ep] - (3) SST.W reg2, disp8 [ep] ## Operation - (1) $adr \leftarrow ep + zero-extend (disp7)$ Store-memory (adr, GR [reg2], Byte) - (2) $adr \leftarrow ep + zero-extend (disp8)$ Store-memory (adr, GR [reg2], Halfword) - (2) $adr \leftarrow ep + zero-extend (disp8)$ Store-memory (adr, GR [reg2], Word) ## **Format** Format IV ## Op code - 15 rrrrr0111ddddddd - rrrrr1001ddddddd ddddddd is the higher 7 bits of disp8. dddddd is the higher 6 bits of disp8. ## Flag CY OV S Ζ SAT ## Instruction - (1) SST.B Short format Store Byte - (2) SST.H Short format Store Half-word - (3) SST.W Short format Store Word ## **Explanation** - (1) Adds the 7-bit displacement, zero-extended to word length, to the element pointer to generate a 32-bit address, and stores the data of the lowest byte of reg2 to the generated address. - (2) Adds the 8-bit displacement, zero-extended to word length, to the element pointer to generate a 32-bit address, and stores the lower half-word data of reg2 to the generated 32-bit address with bit 0 masked to 0. - (3) Adds the 8-bit displacement, zero-extended to word length, to the element pointer to generate a 32-bit address, and stores the word data of reg2 to the generated 32-bit address with bits 0 and 1 masked to 0. ## Caution When the element pointer is added to the 8-bit displacement zero-extended to word length, the lower bits of the result may be masked to 0 depending on the type of data to be accessed (half word, word). ST Store - Instruction format (1) ST.B reg2, disp16 [reg1] - (2) ST.H reg2, disp16 [reg1] - (3) ST.W reg2, disp16 [reg1] ## Operation - (1) $adr \leftarrow GR [reg1] + sign-extend (disp16)$ Store-memory (adr, GR [reg2], Byte) - (2) $adr \leftarrow GR [reg1] + sign-extend (disp16)$ Store-memory (adr, GR [reg2], Halfword) - (2) adr ← GR [reg1] + sign-extend (disp16) Store-memory (adr, GR [reg2], Word) **Format** Format VII ## Op code ddddddddddddd is the higher 15 bits of disp16. ddddddddddddd is the higher 15 bits of disp16. ## Flag CY OV S Ζ SAT ## Instruction - (1) ST.B Store Byte - (2) ST.H Store Half-word - (3) ST.W Store Word ## **Explanation** - (1) Adds the 16-bit displacement, sign-extended to word length, to the data of general register reg1 to generate a 32-bit address, and stores the lowest byte data of general register reg2 to the generated address. - (2) Adds the 16-bit displacement, sign-extended to word length, to the data of general register reg1 to generate a 32-bit address, and stores the lower half-word data of general register reg2 to the generated 32-bit address with bit 0 masked to 0. Therefore, stored data is automatically aligned on a half-word boundary. - (3) Adds the 16-bit displacement, sign-extended to word length, to the data of general register reg1 to generate a 32-bit address, and stores the word data of general register reg2 to the generated 32-bit address with bits 0 and 1 masked to 0. Therefore, stored data is automatically aligned on a word boundary. ## Caution When the data of general register reg1 is added to a 16-bit displacement sign-extended to word length, the lower bits of the result may be masked to 0 depending on the type of data to be accessed (half word, word) to generate an address. # **STSR** Store Contents of System Register Instruction format STSR regID, reg2 **Operation** $GR [reg2] \leftarrow SR [regID]$ Format IX Op code 15 0 31 16 rrrrr1111111RRRRR 0000000010000000 Flag CY - OV – S – Z – SAT – Instruction STSR Store Contents of System Register **Explanation** Stores the contents of a system register specified by system register number (regID) to general register reg2. The contents of the system register are not affected. **Remark** The system register number regID is a number which identifies a system register. Accessing system register which is reserved is prohibited and will lead to undefined results. **SUB** Subtract Instruction format SUB reg1, reg2 Format I **Op code** 15 0 rrrr001101RRRRR Flag CY 1 if a borrow to MSB occurs; otherwise, 0. OV 1 if Overflow occurs; otherwise, 0. S 1 if the result of an operation is negative; otherwise, 0. Z 1 if the result of an operation is 0; otherwise, 0. SAT - Instruction SUB Subtract **Explanation** Subtracts the word data of general register reg1 from the word data of general register reg2, and stores the result to general register reg2. The data of general register reg1 is not affected. # **SUBR** **Subtract Reverse** Instruction format SUBR reg1, reg2 **Operation** $GR [reg2] \leftarrow GR [reg1] - GR [reg2]$ Format I Op code 15 0 rrrrr001100RRRRR Flag CY 1 if a borrow to MSB occurs; otherwise, 0. OV 1 if Overflow occurs; otherwise, 0. S 1 if the result of an operation is negative; otherwise, 0. Z 1 if the result of an operation is 0; otherwise, 0. SAT - Instruction SUBR Subtract Reverse **Explanation** Subtracts the word data of general register reg2 from the word data of general register reg1, and stores the result to general register reg2. The data of general register reg1 is not affected. # **TRAP** **Software Trap** Instruction format TRAP vector **Operation** EIPC $\leftarrow$ PC + 4 (return PC) $EIPSW \leftarrow PSW$ $\mathsf{ECR}.\mathsf{EICC} \quad \leftarrow \mathsf{interrupt} \ \mathsf{code}$ $\begin{array}{ll} \mathsf{PSW}.\mathsf{EP} & \leftarrow 1 \\ \mathsf{PSW}.\mathsf{ID} & \leftarrow 1 \end{array}$ PC $\leftarrow$ 00000040H (vector = 00H-0FH) 00000050H (vector = 10H-1FH) Format X Op code 15 0 31 16 00000111111iiii 000000100000000 Flag CY - OV – S – Z – SAT – **Instruction** TRAP Trap **Explanation** Saves the return PC and PSW to EIPC and EIPSW, respectively; sets the exception code (EICC of ECR) and the flags of the PSW (EP and ID flags); jumps to the address of the trap handler corresponding to the trap vector specified by vector number (0-31), and starts exception processing. The condition flags are not affected. The return PC is the address of the instruction following the TRAP instruction. **TST** Test Instruction format TST reg1, reg2 Format I Op code 15 0 rrrrr001011RRRRR Flag CY - OV ( S 1 if the result of an operation is negative; otherwise, 0. Z 1 if the result of an operation is 0; otherwise, 0. SAT - Instruction TST Test **Explanation** ANDs the word data of general register reg2 with the word data of general register reg1. The result is not stored, and only the flags are changed. The data of general registers reg1 and reg2 are not affected. # TST1 **Test Bit** Instruction format TST1 bit#3, disp16 [reg1] **Operation** $adr \leftarrow GR [reg1] + sign-extend (disp16)$ Z flag ← Not (Load-memory-bit (adr,bit#3)) Format VIII **Op code** 15 0 31 16 11bbb111110RRRRR ddddddddddddddd Flag CY - OV - S - Z 1 if bit NO.bit#3 of memory disp16 [reg1] = 0. 0 if bit NO.bit#3 of memory disp16 [reg1] = 1. SAT - Instruction TST1 Test Bit Explanation Adds the data of general register reg1 to a 16-bit displacement, sign-extended to word length, to generate a 32-bit address. Performs the test on the bit, specified by the 3-bit field "bbb", at the byte data location referenced by the generated address. If the specified bit is 0, the Z flag is set to 1; if the bit is 1, the Z flag is reset to 0. The byte data, including the specified bit, is not affected. **XOR** **Exclusive Or** Instruction format XOR reg1, reg2 Format I Op code 15 0 rrrrr001001RRRRR Flag CY - OV ( S 1 if the result of an operation is negative; otherwise, 0. Z 1 if the result of an operation is 0; otherwise, 0. SAT - Instruction XOR Exclusive Or **Explanation** Exclusively ORs the word data of general register reg2 with the word data of general register reg1, and stores the result to general register reg2. The data of general register reg1 is not affected. # **XORI** **Exclusive Or Immediate** Instruction format XORI imm16, reg1, reg2 **Operation** GR [reg2] $\leftarrow$ GR [reg1] XOR zero-extend (imm16) Format VI Flag CY - OV 0 S 1 if the result of an operation is negative; otherwise, 0. Z 1 if the result of an operation is 0; otherwise, 0. SAT - Instruction XORI Exclusive Or Immediate (16-bit) **Explanation** Exclusively ORs the word data of general register reg1 with a 16-bit immediate data, zero- extended to word length, and stores the result to general register reg2. The data of general register reg1 is not affected. # 5.4 Number of Instruction Execution Clock Cycles The number of instruction execution clock cycles differ depending on the combination of instructions. For details, refer to **CHAPTER 8 PIPELINE**. Table 5-10 shows a list of the number of instruction execution clock cycles. Table 5-10. List of Number of Instruction Execution Clock Cycles (1/3) | Instructions | Mnemonic | Operand | Byte | Execution clock | |---------------|------------|---------------|------|-----------------| | IIIStructions | Millemonic | Орегани | | i – r – l | | Load/store | SLD.B | disp7 [ep], r | 2 | 1 – 1 – 2 | | | SLD.H | disp8 [ep], r | 2 | 1 – 1 – 2 | | | SLD.W | disp8 [ep], r | 2 | 1 – 1 – 2 | | | SST.B | r, disp7 [ep] | 2 | 1 – 1 – 1 | | | SST.H | r, disp8 [ep] | 2 | 1 – 1 – 1 | | | SST.W | r, disp8 [ep] | 2 | 1 – 1 – 1 | | | LD.B | disp16 [R], r | 4 | 1 – 1 – 2 | | | LD.H | disp16 [R], r | 4 | 1 – 1 – 2 | | | LD.W | disp16 [R], r | 4 | 1 – 1 – 2 | | | ST.B | r, disp16 [R] | 4 | 1 – 1 – 1 | | | ST.H | r, disp16 [R] | 4 | 1 – 1 – 1 | | | ST.W | r, disp16 [R] | 4 | 1 – 1 – 1 | | Arithmetic | MOV | R, r | 2 | 1 – 1 – 1 | | operation | MOV | imm5, r | 2 | 1 – 1 – 1 | | | MOVEA | imm16, R, r | 4 | 1 – 1 – 1 | | | MOVHI | imm16, R, r | 4 | 1 – 1 – 1 | | | DIVH | R, r | 2 | 36 - 36 - 36 | | | MULH | R, r | 2 | 1 – 1 – 2 | | | MULH | imm5, r | 2 | 1 – 1 – 2 | | | MULHI | imm16, R, r | 4 | 1 – 1 – 2 | | | ADD | R, r | 2 | 1 – 1 – 1 | | | ADD | imm5, r | 2 | 1 – 1 – 1 | | | ADDI | imm16, R, r | 4 | 1 – 1 – 1 | | | CMP | R, r | 2 | 1 – 1 – 1 | | | CMP | imm5, r | 2 | 1 – 1 – 1 | | | SUBR | R, r | 2 | 1 – 1 – 1 | | | SUB | R, r | 2 | 1 – 1 – 1 | | | SETF | cccc, r | 4 | 1 – 1 – 1 | | Saturated | SATSUBR | R, r | 2 | 1 – 1 – 1 | | operation | SATSUB | R, r | 2 | 1 – 1 – 1 | | | SATADD | R, r | 2 | 1 – 1 – 1 | | | SATADD | imm5, r | 2 | 1 – 1 – 1 | | | SATSUBI | imm16, R, r | 4 | 1 – 1 – 1 | Table 5-10. List of Number of Instruction Execution Clock Cycles (2/3) | Instructions Mnemoni | | Operand | | Byte | Execution clock | |----------------------|----------------|-------------------|---------------------------------|------|-------------------------| | III3ti dotions | WITCHIOTIC | Operand | | Dyto | i – r – l | | Logical | NOT | R, r | | 2 | 1 – 1 – 1 | | operation | OR | R, r | | 2 | 1 – 1 – 1 | | | XOR | R, r | R, r | | 1 – 1 – 1 | | | AND | R, r | | 2 | 1 – 1 – 1 | | | TST | R, r | | 2 | 1 – 1 – 1 | | | SHR | imm5, | r | 2 | 1 – 1 – 1 | | | SAR | imm5, | r | 2 | 1 – 1 – 1 | | | SHL | imm5, | r | 2 | 1 – 1 – 1 | | | ORI | imm16 | 5, R, r | 4 | 1 – 1 – 1 | | | XORI | imm16 | 6, R, r | 4 | 1 – 1 – 1 | | | ANDI | imm16 | 6, R, r | 4 | 1 – 1 – 1 | | | SHR | R, r | | 4 | 1 – 1 – 1 | | | SAR | R, r | | 4 | 1 – 1 – 1 | | | SHL | R, r | | 4 | 1 – 1 – 1 | | Branch | JMP | [R] | [R] | | 3 – 3 – 3 | | | JR | disp22 | | 4 | 3 – 3 – 3 | | | JARL | disp22 | 2, r | 4 | 3 – 3 – 3 | | Е | Bcond | disp9 | When condition is satisfied | 2 | 3 – 3 – 3 | | | | | When condition is not satisfied | 2 | 1 – 1 – 1 | | Bit | SET1 | bit#3, | disp16 [R] | 4 | 4 - 4 - 4 | | manipulation | CLR1 | bit#3, disp16 [R] | | 4 | 4 - 4 - 4 | | | NOT1 | bit#3, disp16 [R] | | 4 | 4 – 4 – 4 | | | TST1 | bit#3, | disp16 [R] | 4 | 3 – 3 – 3 | | Special | LDSR | R, SR | | 4 | 1 — 1 — <sup>Note</sup> | | | STSR | SR, r | | 4 | 1 – 1 – 1 | | | NOP | - | | 2 | 1 – 1 – 1 | | | DI | vector | | 4 | 1 – 1 – 1 | | | EI | | | 4 | 1 – 1 – 1 | | | TRAP | | | 4 | 4 – 4 – 4 | | | HALT | | | 4 | 1 – 1 – 1 | | | RETI | | | 4 | 4 – 4 – 4 | | | Undefined inst | ruction o | code trap | 4 | 4 - 4 - 4 | Note When accessing EIPC, FEPC: 3 When accessing EIPSW, FEPSW, PSW: 1 Table 5-10. List of Number of Instruction Execution Clock Cycles (3/3) # Operand | Symbol | Meaning | |---------------------|--------------------------------------------------------| | R: reg1 | General register (used as source register) | | r: reg2 | General register (mainly used as destination register) | | SR: System Register | System register | | immx: immediate | ×-bit immediate | | dispx: displacement | ×-bit displacement | | bit#3: bit number | 3-bit data for bit number specification | | ep: Element Pointer | Element pointer | | B: Byte | Byte (8 bits) | | H: Halfword | Half-word (16 bits) | | W: Word | Word (32 bits) | | cccc: conditions | 4-bit data condition code specification | | vector | 5-bit data for trap vector (00H-1FH) specification | ## **Execution clock** | Symbol | Meaning | |------------|-------------------------------------------------------------------------------------------------------------------------| | i: issue | When other instruction is executed immediately after executing an instruction | | r: repeat | When the same instruction is repeatedly executed immediately after the instruction has been executed | | I: latency | When a subsequent instruction uses the result of execution of the preceding instruction immediately after its execution | ## CHAPTER 6 INTERRUPT AND EXCEPTION Interrupts are events that occur independently of the program execution and are divided into two types: maskable and non-maskable interrupts. In contrast, an exception is an event whose occurrence is dependent on the program execution. There is no major difference between the interrupt and exception in terms of control flow. However, the interrupt takes precedence over the exception. The V850 can process various interrupt requests from the on-chip peripheral hardware and external sources. In addition, exception processing can be started by an instruction (TRAP instruction) and by occurrence of an exception event (exception trap). The interrupts and exceptions supported in the V850 family are described below. When an interrupt or exception is deleted, control is transferred to a handler whose address is determined by the source of the interrupt or exception. The source of the event is specified by the exception code that is stored in the exception cause register (ECR). Each handler analyzes the exception cause register (ECR) and performs appropriate interrupt servicing or exception handling. The return PC and PSW are written to the status saving registers (EIPC, EIPSW/FEPC, FEPSW). To return execution from interrupt or exception processing, use the RETI instruction. Read the return PC and PSW from the status saving register, and transfer control to the return PC. - Types of interrupt/exception processing - The V850 family handles the following four types of interrupts/exceptions: - · Non-maskable interrupt - · Maskable interrupt - · Software exception - · Exception trap Table 6-1. Interrupt/Exception Codes | Interrupt/Exception Cause | | Classification | Exception Code | Handler Address | Return PC | |---------------------------|------------------|----------------|-------------------|------------------|---------------| | Name | Trigger | Glacomoation | on Exception code | Tianulei Address | Retain 10 | | NMI | NMI input | Interrupt | 0010H | 00000010H | next PCNote 2 | | Maskable interrupt | Note 1 | Interrupt | Note 1 | Note 1 | next PCNote 2 | | TRAP0n (n = 0 - FH) | TRAP instruction | Exception | 004nH | 00000040H | next PC | | TRAP1n (n = 0 - FH) | TRAP instruction | Exception | 005nH | 00000050H | next PC | | ILGOP | Illegal op code | Exception | 006nH | 00000060H | next PCNote 3 | - Notes 1. Differs depending on the type of the maskable interrupts. - 2. If an interrupt is acknowledged during execution of a DIVH (divide) instruction, the Restore PC becomes the PC value for the currently executed instruction (DIVH). - 3. The execution address of the illegal instruction is obtained by "retention PC-4" when an illegal op code exception occurs. The return PC is the PC saved to the EIPC or FEPC when interrupt/exception processing is started. "next PC" is the PC that starts processing after interrupt/exception processing. The processing of maskable interrupts is controlled by the user through the INTC unit (interrupt controller). The INTC is different for each device in the V850 family due to the variations of on-chip peripherals, interrupt/exception causes and exception codes. ## 6.1 Interrupt Servicing #### 6.1.1 Maskable interrupt The maskable interrupt can be masked by the program status word (PSW). The INTC issues an interrupt request to the CPU, based on the accepted interrupt with the highest priority. If a maskable interrupt occurs due to INT input, the processor performs the following steps, and transfers control to the handler routine. - (1) Saves restore PC to EIPC. - (2) Saves current PSW to EIPSW. - (3) Writes exception code to lower half-word of ECR (EICC). - (4) Sets ID bit of PSW and clears EP bit. - (5) Sets handler address for each interrupt to PC and transfers control. Interrupts are held pending in the interrupt controller (INTC) when one of the following two conditions occur: when the interrupt input (INT) is masked by its INTC, or when an interrupt service routine is currently being executed (when the NP bit of the PSW is 1 or when the ID bit of the PSW is 1). Interrupts are enabled by clearing the mask condition and by resetting the NP and ID bits of the PSW to 0 with the LDSR and RETI instructions, which will be enabling servicing of a new or already pending interrupt. The EIPC and EIPSW are used as the status saving registers. These registers must be saved by program to enable nesting of interrupts because there is only one set of EIPC and EIPSW is provided. Bits 31 through 24 of the EIPC and bits 31 through 8 of the EIPSW are fixed to 0. Figure 6-1 illustrates how the maskable interrupt is serviced. Figure 6-1. Maskable Interrupt Servicing Format #### 6.1.2 Non-maskable interrupt The non-maskable interrupt cannot be disabled by an instruction and therefore can be always accepted. The non-maskable interrupt of the V850 family is generated by the NMI input. When the non-maskable interrupt is generated by the NMI input, the processor performs the following steps, and transfers control to the handler routine. - (1) Saves restore PC to FEPC. - (2) Saves current PSW to FEPSW. - (3) Writes exception code to higher half-word of ECR (FECC). - (4) Sets NP and ID bits of PSW and clears EP bit. - (5) Sets handler address (00000010H) for the non-maskable interrupt to PC and transfers control. Non-maskable interrupts are held pending in the INTC when other non-maskable interrupt is currently being executed (when the NP bit of the PSW is 1). Non-maskable interrupts are enabled by resetting the NP bit of the PSW to 0 with the RETI and LDSR instructions, which will be enabling servicing of a new or already pending interrupt. The FEPC and FEPSW are used as the status saving registers. Figure 6-2 illustrates how the non-maskable interrupt is serviced. Non-Maskable Interrupt (NMI) Occurs PSW.NP Interrupt Servicing Pending **FEPC** Restore PC **FEPSW PSW ECR.FECC Exception Code** PSW.NP PSW.EP 0 PSW.ID PC 00000010H Interrupt Servicing Figure 6-2. Non-maskable Interrupt Servicing Format #### 6.2 Exception Processing #### 6.2.1 Software exception A software exception is generated when the CPU executes the TRAP instruction and is always accepted. If a software exception occurs, the CPU performs the following steps, and transfers control to the handler routine. - (1) Saves restore PC to EIPC. - (2) Saves current PSW to EIPSW. - (3) Writes exception code to lower 16 bits (EICC) of ECR (interrupt cause). - (4) Sets EP and ID bits of PSW. - (5) Sets handler address (00000040H or 00000050H) for software exception to PC and transfers control. Figure 6-3 illustrates how the software exception is processed. Figure 6-3. Software Exception Processing Format Handler address: 00000040H (vector = 0nH) 00000050H (vector = 1nH) #### 6.2.2 Exception trap The exception trap is an interrupt requested when an instruction is illegally executed. The exception trap of the V850 family is generated by an illegal op code instruction code trap (ILGOP: ILleGal OPcode trap). An illegal op code instruction has an instruction code with an op code (bits 5 through 10) of 111111B and a subop code (bits 23 through 26) of 0011B through 1111B. When this kind of an illegal op code instruction is executed, an illegal op code instruction code trap occurs. Figure 6-4. Illegal Instruction Code Remark x: don't care □: Op code/sub-op code portion If an exception trap occurs, the CPU performs the following steps, and transfers control to the handler routine. - (1) Saves restore PC to EIPC. - (2) Saves current PSW to EIPSW. - (3) Writes exception code to lower 16 bits (EICC) of ECR. - (4) Sets EP and ID bits of PSW. - (5) Sets handler address (00000060H) for exception trap to PC and transfers control. Figure 6-5 illustrates how the exception trap is processed. Figure 6-5. Exception Trap Processing Format The execution address of the illegal instruction is obtained by "restore PC - 4" when an exception trap occurs. Caution In addition to the defined op codes and illegal op codes, there is a range of codes not recognized by this processor. If an instruction corresponding to these codes is executed, normal operation is undetermined. #### 6.3 Restoring from Interrupt/Exception All restoration from interrupt servicing/exception processing is executed by the RETI instruction. With the RETI instruction, the processor performs the following steps, and transfers control to the address of the restore PC. - (1) If the EP bit of the PSW is 0 and the NP bit of the PSW is 1, the restore PC and PSW are read from the FEPC and FEPSW. Otherwise, the restore PC and PSW are read from the EIPC and EIPSW. - (2) Control is transferred to the address of the restored PC and PSW. When execution has returned from exception processing or non-maskable interrupt servicing, the NP and EP bits of the PSW must be set to the following values by using the LDSR instruction immediately before the RETI instruction, in order to restore the PC and PSW normally: Figure 6-6 illustrates how restoration from interrupt/exception is performed. Figure 6-6. Restoration from Interrupt/Exception [MEMO] #### **CHAPTER 7 RESET** When a low-level signal is input to the RESET pin, the system is reset, and each on-chip hardware is initialized. # 7.1 Initializing When a low-level signal is input to the $\overline{\text{RESET}}$ pin, the system is reset, and each hardware register is set in the status shown in Table 7-1. When the $\overline{\text{RESET}}$ signal goes high, program execution begins. If necessary, re-initialize the contents of each register by program control. Table 7-1. Register Status after Reset | Hardware (symbol) | | Status after Reset | | | |----------------------------------|----------------|---------------------------------|--|--| | Program counter | PC | 00000000H | | | | Interrupt status saving register | EIPC<br>EIPSW | Undefined<br>Undefined | | | | NMI status saving register | FEPC<br>FEPSW | Undefined<br>Undefined | | | | Exception cause register (ECR) | FECC<br>EICC | 0000H<br>0000H | | | | Program status word | PSW | 00000020H | | | | General register | r0<br>r1 - r31 | Fixed to 00000000H<br>Undefined | | | # 7.2 Starting Up All devices in the V850 family begin program execution from address 00000000H after it has been reset. After reset, no immediate interrupt requests are accepted. To enable interrupts, clear the ID bit of the program status word (PSW) to 0. [MEMO] #### **CHAPTER 8 PIPELINE** The V850 family is based on the RISC architecture and executes almost all the instructions in one clock cycle under control of a 5-stage pipeline. The processor uses a 5-stage pipeline. The operation to be performed in each stage is as follows: | IF (instruction fetch) | In struction is fetched and fetch pointer is incremented. | |-------------------------------------------------------|------------------------------------------------------------------| | ID (instruction decode) | Instruction is decoded, immediate data is generated, | | | and register is read. | | EX (execution of ALU, multiplier, and barrel shifter) | The instruction is executed. | | MEM (memory access) | Memory at specified address is accessed. | | WB (write back) | Result of execution is written to register. | #### 8.1 Outline of Operation The instruction execution sequence of the V850 family consists of five stages including fetch and write back stages. The execution time of each stage differs depending on the type of the instruction and the type of the memory to be accessed. As an example of pipeline operation, Figure 8-1 shows the processing of the CPU when nine standard instructions are executed in succession. Figure 8-1. Example of Executing Nine Standard Instructions Executes Instruction Every 1 Clock Cycle ① through ③ in the figure above indicate the states of the CPU. In each state, write back of instruction n, memory access of instruction n+1, execution of instruction n+2, decoding of instruction n+3, and fetching of instruction n+4 are simultaneously performed. It takes five clock cycles to process a standard instruction, including fetching and write back. Because five instructions can be processed at the same time, however, a standard instruction can be executed in 1 clock cycle on the average. #### 8.2 Pipeline Flow During Execution of Instructions This section explains the pipeline flow during the execution of instructions. During instruction fetch (IF stage) and memory access (MEM stage), the internal ROM/PROM and the internal RAM are accessed, respectively. In this case, the IF and MEM stages are processed in 1 clock. In all other cases, the required time for access consists of the fixed access time, with the addition in some cases of the path wait time. Access times are shown in Figure 8-2 below. Figure 8-2. Access Times (in clocks) | Resource (bus width) Stage | Internal ROM/PROM<br>(32 bits) | Internal RAM<br>(32 bits) | Internal peripheral I/O (8/16 bits) | External memory (16 bits) | |----------------------------|--------------------------------|---------------------------|-------------------------------------|---------------------------| | Instruction fetch | 1 | 3 | Not possible | 3 + n | | Memory access (MEM) | 3 | 1 | 3 + n | 3 + n | Remark n: Wait number #### 8.2.1 Load instructions [Instructions] LD, SLD [Pipeline] Load instruction Next instruction 1 2 3 4 5 6 IF ID EX MEM WB IF ID EX MEM WB [Description] The pipeline consists of 5 stages, IF, ID, EX, MEM, and WB. If an instruction using the execution result is placed immediately after the load instruction, data wait time occurs. For details, see 8.3 Pipeline Disorder. #### 8.2.2 Store instructions [Instructions] ST, SST [Pipeline] Store instruction Next instruction ① ② ③ ④ ⑤ ⑥ IF ID EX MEM WB : IF ID EX MEM WB [Description] The pipeline consists of 5 stages, IF, ID, EX, MEM and WB. However, no operation is performed in the WB stage, because no data is written to registers. # 8.2.3 Arithmetic operation instructions (excluding multiply and divide instructions) [Instructions] MOV, MOVEA, MOVHI, ADD, ADDI, CMP, SUB, SUBR, SETF [Pipeline] Arithmetic operation Next instruction 1 2 3 4 5 6 IF ID EX MEM WB IF ID EX MEM WB [Description] The pipeline consists of 5 stages, IF, ID, EX, MEM and WB. However, no operation is performed in the MEM stage, because memory is not accessed. #### 8.2.4 Multiply instructions [Instructions] MULH, MULHI [Pipeline] (1) When next instruction is not multiply instruction | | 1 | 2 | 3 | 4 | (5) | 6 | |----------------------|----|----|-----|-----|-----|----| | Multiply instruction | IF | ID | EX1 | EX2 | WB | | | Next instruction | | IF | ID | EX | MEM | WB | (2) When next instruction is multiply instruction | | 1 | 2 | 3 | 4 | (5) | 6 | |------------------------|----|----|-----|-----|-----|----| | Multiply instruction 1 | IF | ID | EX1 | EX2 | WB | | | Multiply instruction 2 | | IF | ID | EX1 | EX2 | WB | [Description] The pipeline consists of 5 stages, IF, ID, EX1, EX2, and WB. There is no MEM stage. The EX stage requires 2 clocks, but the EX1 and EX2 stages can operate independently. Therefore, the number of clocks for instruction execution is always 1, even if several multiply instructions are executed in a row. However, if an instruction using the execution result is placed immediately after a multiply instruction, data wait time occurs. For details, see Section 8.3 Pipeline Disorder. #### 8.2.5 Divide instruction [Instructions] DIVH | [Pipeline] | | 1 | 2 | 3 | 4 | (( | • | 37) | 38 | 39 | 40 | <b>41</b> | 42 | |------------|------------------------|----|----|-----|-----|----|---|------|------|-----|-----|-----------|----| | [poo] | Divide instruction | IF | ID | EX1 | EX2 | (( | · | EX35 | EX36 | MEM | WB | | | | | Next instruction | | IF | _ | _ | )) | · | _ | ID | EX | MEM | WB | | | | Next to next instructi | on | | | • | | ) | | IF | ID | EX | MEM | WB | -: Idle inserted for wait [Description] The pipeline consists of 40 stages, IF, ID, EX1 to EX36, MEM, and WB. The EX stage requires 36 clocks. No operation is performed in the MEM stage, because memory is not accessed. #### 8.2.6 Logical operation instructions [Instructions] NOT, OR, ORI, XOR, XORI, AND, ANDI, TST, SHR, SAR, SHL [Pipeline] Logical operation instruction Next instruction | | 1 | 2 | 3 | 4 | <b>⑤</b> | 6 | |---|----|----|----|-----|----------|----| | | IF | ID | EX | MEM | WB | | | _ | | IF | ID | EX | MEM | WB | [Description] The pipeline consists of 5 stages, IF, ID, EX, MEM, and WB. No operation is performed in the MEM stage, because memory is not accessed. #### 8.2.7 Saturation operation instructions [Instructions] SATADD, SATSUB, SATSUBI, SATSUBR [Pipeline] Saturation operation instruction Next instruction [Description] The pipeline consists of 5 stages, IF, ID, EX, MEM, and WB. However, no operation is performed in the MEM stage, because memory is not accessed. #### 8.2.8 Branch instruction #### (1) Conditional branch instructions [Instructions] Boond instructions (BGT, BGE, BLT, BLE, BH, BNL, BL, BNH, BE, BNE, BV, BNV, BN, BP, BC, BNC, BZ, BNZ, BSA): Except BR instruction [Pipeline] (a) When the condition is not realized (b) When the condition is realized IF ×: Instruction fetch that is not executed $\mathsf{ID} \times$ : Instruction decode that is not executed [Description] The pipeline consists of 5 stages, IF, ID, EX, MEM, and WB. However, no operation is performed in the MEM and WB stages, because memory is not accessed and no data is written to registers. (a) When the condition is not realized The number of execution clocks for the branch instruction is 1. (b) When the condition is realized The number of execution clocks for the branch instruction is 3. IF stage of the next instruction and next to next instruction of the branch instruction is not executed. #### (2) Unconditional branch instructions [Instructions] JMP, JR, JARL, BR [Pipeline] Unconditional Unconditional branch instruction IF ID EX MEM Branch destination instruction IF ID EX MEM WB IF x : Instruction fetch that is not executed WBNote: No operation is performed in the case of the JMP instruction, JR instruction, and BR instruction, but in the case of the JARL 6 (7) (8) instruction, data is written to the restore PC. [Description] The pipeline consists of 5 stages, IF, ID, EX, MEM, and WB. However, no operation is performed in the MEM and WB stages, because memory is not accessed and no data is written to registers. However, in the case of the JARL instruction, data is written to the restore PC in the WB stage. Also, the IF stage of the next instruction of the branch instruction is not executed. # 8.2.9 Bit manipulation instructions #### (1) SET1, CLR1, NOT1 [Pipeline] | SET4 CLD4 NOT4 | 1 | 2 | 3 | 4 | (5) | 6 | 7 | 8 | 9 | 10 | |------------------------------|----|----|-----|-----|-----|-----|-----|-----|-----|----| | SET1, CLR1, NOT1 instruction | IF | ID | EX1 | MEM | EX2 | EX3 | MEM | WB | ] | | | Next instruction | | IF | _ | _ | _ | ID | EX | MEM | WB | | | Next to next instruction | on | | | | | IF | ID | EX | MEM | WB | -: Idle inserted for wait [Description] The pipeline consists of 8 stages, IF, ID, EX1, MEM, EX2, EX3, MEM, and WB. However, no operation is performed in the WB stage, because no data is written to registers. In the case of these instructions, the memory access is read modify write, and the EX and MEM stages require 3 and 2 clocks, respectively. #### (2) TST1 [Pipeline] TST1 instruction Next instruction -: Idle inserted for wait [Description] The pipeline consists of 8 stages, IF, ID, EX1, MEM, EX2, EX3, MEM, and WB. However, no operation is performed in the second MEM and WB stages, because there is no second memory access nor data write to registers. In the case of this instruction, the memory access is read modify write, and the EX and MEM stage require 3 and 2 clocks, respectively. #### 8.2.10 Special instructions #### (1) LDSR, STSR LD [Pipeline] Ne | | 1 | 2 | 3 | 4 | <b>⑤</b> | 6 | |-----------------------|----|----|----|-----|----------|----| | OSR, STSR instruction | IF | ID | EX | MEM | WB | | | ext instruction | | IF | ID | EX | MEM | WB | [Description] The pipeline consists of 5 stages, IF, ID, EX, MEM, and WB. However, no operation is performed in the MEM stage, because memory is not accessed. Also, if the STSR instruction using the EIPC and FEPC system registers is placed immediately after the LDSR instruction setting these registers, data wait time occurs. For details, see Section 8.3 Pipeline Disorder. #### (2) NOP [Pipeline] NOP instruction Next instruction [Description] The pipeline consists of 5 stages, IF, ID, EX, MEM, and WB. However, no operation is performed in the EX, MEM and WB stages, because no operation and no memory access is executed, and no data is written to registers. # (3) EI, DI [Pipeline] EI, DI instruction Next instruction [Description] The pipeline consists of 5 stages, IF, ID, EX, MEM, and WB. However, no operation is performed in the MEM and WB stages, because memory is not accessed and data is not written to registers. #### (4) HALT #### [Pipeline] -: Idle inserted for wait [Description] The pipeline consists of 5 stages, IF, ID, EX, MEM and WB. No operation is performed in the MEM and WB stages, because memory is not accessed and no data is written to registers. Also, for the next instruction, the ID stage is delayed until the HALT state is released. # (5) TRAP IF x: Instruction fetch that is not executed ID1 : Trap code detectID2 : Address generate [Description] The pipeline consists of 6 stages, IF, ID1, ID2, EX, MEM, and WB. However, no operation is performed in the MEM stage, because memory is not accessed. The ID stage requires 2 clocks. Also, the IF stage of the next instruction and next to next instruction is not executed. # (6) RETI IF x: Instruction fetch that is not executed ID1 : Register selectID2 : Read EIPC/FEPC [Description] The pipeline consists of 6 stages, IF, ID1, ID2, EX, MEM, and WB. However, no operation is performed in the MEM and WB stages, because memory is not accessed and no data is written to registers. The ID stage requires 2 clocks. Also, the IF stage of the next instruction and next to next instruction is not executed. #### 8.3 Pipeline Disorder The pipeline consists of 5 stages from IF (Instruction Fetch) to WB (Write Back). Each stage basically requires 1 clock for processing, but the pipeline may become disordered, causing the number of execution clocks to increase. This section describes the main causes of pipeline disorder. #### 8.3.1 Alignment hazard If the branch destination instruction address is not word aligned (A1=1, A0=0) and is 4 bytes in length, it is necessary to repeat IF twice in order to align instructions in word units. This is called align hazard. For example, let us suppose that instructions a to e are placed from address X0H, and that instruction b consists of 4 bytes, and the other instructions each consist of 2 bytes. In this case, instruction b is placed at X2H (A1=1, A0=0), and is not word aligned (A1=0, A0=0). Therefore, when this instruction b becomes the branch destination instruction, an align hazard occurs. When an align hazard occurs, the number of execution clocks of the branch instruction becomes 4. Figure 8-3. Align Hazard Example Align hazard can be prevented through the following handling in order to obtain faster instruction execution. - · Use 2-byte branch destination instruction. - Use 4-byte instructions placed at word boundaries (A1=0, A0=0) for branch destination instructions. #### 8.3.2 Referencing execution result of load instruction For load instructions (LD, SLD), data read in the MEM stage is saved during the WB stage. Therefore, if the contents of the same register are used by the instruction immediately after the load instruction, it is necessary to delay the use of the register by this later instruction until the load instruction has ended using that register. This is called a hazard. The V850 family has an interlock function that causes the CPU to automatically handle this hazard by delaying the ID stage of the next instruction. The V850 family also has a short path that allows the data read during the MEM stage to be used in the ID stage of the next instruction. This short path allows data to be read with the load instruction during the MEM stage and the use of this data in the ID stage of the next instruction with the same timing. As a result of the above, when using the execution result in the instruction following immediately after, the number of execution clocks of the load instruction is 2. Figure 8-4. Example of Execution Result of Load Instruction IL: Idle inserted for data wait by interlock function - : Idle inserted for wait : Short path As described above, when an instruction placed immediately after a load instruction uses its execution result, a data wait time occurs due to the interlock function, and the execution speed is lowered. This drop in execution speed can be avoided by placing instructions that use the execution result of a load instruction at least 2 instructions after the load instruction. #### 8.3.3 Referencing execution result of multiply instruction For multiply instructions (MULH, MULHI), the operation result is saved to the register in the WB stage. Therefore, if the contents of the same register are used by the instruction immediately after the multiply instruction, it is necessary to delay the use of the register by this later instruction until the multiply instruction has ended using that register (occurrence of hazard). The V850 family's interlock function delays the ID stage of the instruction following immediately after. A short path is also provided that allows the EX2 stage of the multiply instruction and the multiply instruction's operation result to be used in the ID stage of the instruction following immediately after with the same timing. Figure 8-5. Example of Execution Result of Multiply Instruction IL: Idle inserted for data wait by interlock function Idle inserted for wait : Short path As described above, when an instruction placed immediately after a multiply instruction uses its execution result, a data wait time occurs due to the interlock function, and the execution speed is lowered. This drop in execution speed can be avoided by placing instructions that use the execution result of a multiply instruction at least 2 instructions after the multiply instruction. #### 8.3.4 Referencing execution result of LDSR instruction for EIPC and FEPC When using the LDSR instruction to set the data of the EIPC and FEPC system registers, and immediately after referencing the same system registers with the STSR instruction, the use of the system registers for the STSR instruction is delayed until the setting of the system registers with the LDSR instruction is completed (occurrence of hazard). The V850 family's interlock function delays the ID stage of the STSR instruction immediately after. As a result of the above, when using the execution result of the LDSR instruction for EIPC and FEPC for an STSR instruction following immediately after, the number of execution clocks of the LDSR instruction becomes 3. | LDSR instruction | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | |------------------------------------|----|----|----|-----|----|----|-----|-----|-----|----| | (LDSR R6, 0) Note | IF | ID | EX | MEM | WB | | | | | | | STSR instruction (STSR 0, R7) Note | | IF | IL | IL | ID | EX | MEM | WB | | _ | | Next instruction | | | IF | _ | _ | ID | EX | MEM | WB | | | Next to next instructi | on | | | | | IF | ID | EX | MEM | WB | IL: Idle inserted for data wait by interlock function - : Idle inserted for wait Note System register 0 used for the LDSR and STSR instructions designates EIPC. As described above, when an STSR instruction is placed immediately after an LDSR instruction that uses the operand EIPC or FEPC, and that STSR instruction uses the LDSR instruction execution result, the interlock function causes a data wait time to occur, and the execution speed is lowered. This drop in execution speed can be avoided by placing STSR instructions that reference the execution result of the preceding LDSR instruction at least 3 instructions after the LDSR instruction. # 8.3.5 Cautions when creating programs When creating programs, pipeline disorder can be avoided and instruction execution speed can be raised by observing the following cautions. - Place instructions that use the execution result of load instructions (LD, SLD) at least 2 instructions after the load instruction. - Place instructions that use the execution result of multiply instructions (MULH, MULHI) at least 2 instructions after the multiply instruction. - If using the STSR instruction to read the setting results written to the EIPC or FEPC registers with the LDSR instruction, place the STSR instruction at least 3 instructions after the LDSR instruction. - For the first branch destination instruction, use a 2-byte instruction, or a 4-byte instruction placed at the word boundary. #### 8.4 Additional Items Related to Pipeline #### 8.4.1 Harvard architecture The V850 family uses the Harvard architecture to operate an instruction fetch path from internal ROM and a memory access path to internal RAM independently. This eliminates path arbitration conflicts between the IF and MEM stages and allows orderly pipeline operation. #### (1) V850 family (Harvard architecture) The MEM stage of instruction 1 and the IF stage of instruction 4, as well as the MEM stage of instruction 2 and the IF stage of instruction 5 can be executed simultaneously with orderly pipeline operation. | | 1 | 2 | 3 | 4 | (5) | 6 | 7 | 8 | 9 | |---------------|----|----|----|-----|-----|-----|-----|-----|----| | Instruction 1 | IF | ID | EX | MEM | WB | | _ | | | | Instruction 2 | | IF | ID | EX | MEM | WB | | _ | | | Instruction 3 | | | IF | ID | EX | MEM | WB | | _ | | Instruction 4 | | | | IF | ID | EX | MEM | WB | | | Instruction 5 | | | | | IF | ID | EX | MEM | WB | #### (2) Not V850 family (Other than Harvard architecture) The MEM stage of instruction 1 and the IF stage of instruction 4, in addition to the MEM stage of instruction 2 and the IF stage of instruction 5 are in contention, causing path waiting to occur and slower execution time due to disorderly pipeline operation. -: Idle inserted for wait #### 8.4.2 Short path The V850 family provides on chip a short path that allows the use of the execution result of the preceding instruction by the following instruction before write back (WB) is completed for the previous instruction. # **Example 1.** Execution result of arithmetic operation instruction and logical operation used by instruction following immediately after • V850 family (on-chip short path) The execution result of the preceding instruction can be used for the ID stage of the instruction following immediately after as soon as the result is out (EX stage), without having to wait for write back to be completed. (1) (2) ADD 2, R6 | IF | ID | E MOV R6, R7 | IF | II | 1 | 2 | 3 | 4 | (5) | 6 | |----|----|------|-----|-----|----| | IF | ID | EX | MEM | WB | | | | IF | ID 🕴 | EX | MEM | WB | Not V850 family (No short path) The ID stage of the instruction following immediately after is delayed until write back of the previous instruction is completed. ADD 2, R6 MOV R6, R7 | 1 | 2 | 3 | 4 | (5) | 6 | 7 | 8 | |----|----|----|-----|-----|----|-----|----| | IF | ID | EX | МЕМ | WB | | | | | | IF | _ | - | ID | EX | МЕМ | WB | -: Idle inserted for wait : Short path Example 2. Data read from memory by the load instruction used by instruction following immediately after • V850 family (on-chip short path) The execution result of the preceding instruction can be used for the ID stage of the instruction following immediately after as soon as the result is out (MEM stage), without having to wait for write back to be completed. 1 2 3 4 (5) 6 7 8 9 lF LD [R4], R6 ID EX MEM I WB \* ADD 2, R6 IF ΙL ID EX MEM WB IF ID ΕX MEM WB Next instruction IF ID ΕX WB Next to next instruction MEM Not V850 family (No short path) The ID stage of the instruction following immediately after is delayed until write back of the previous instruction is completed. IL: Idle inserted for data wait by interlock function Idle inserted for wait : Short path # APPENDIX A INSTRUCTION MNEMONIC (IN ALPHABETICAL ORDER) This appendix summarizes the properties and functions of the V850 family's instructions to allow users to know the outline of the desired instruction quickly. Instructions are listed in alphabetical order of their mnemonics. The illustration and table shown below indicates how to read this appendix and what each legend and word means. Table A-1. Instruction Mnemonic (in alphabetical order) (1/7) | Instruction<br>Mnemonic | Operand | Format | CY | OV | S | Z | SAT | Instruction Function | |-------------------------|----------------------|---------|----|----|---|---|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ADD | reg1, reg2 | I<br>II | * | * | * | * | _ | Add. Adds the word data of reg1 to the word data of reg2, and stores the result to reg2. Add. Adds the 5-bit immediate data, sign- | | 7.52 | 5, 1092 | | | | | | | extended to word length, to the word data of reg2, and stores the result to reg2. | | ADDI | imm16, reg1, reg2 | VI | * | * | * | * | - | Add. Adds the 16-bit immediate data, sign-extended to word length, to the word data of reg1, and stores the result to reg2. | | AND | reg1, reg2 | I | - | 0 | * | * | - | AND. ANDs the word data of reg2 with the word data of reg1, and stores the result to reg2. | | ANDI | imm16, reg1, reg2 | VI | - | 0 | * | * | - | AND. ANDs the word data of reg1 with the 16-bit immediate data, zero-extended to word length, and stores the result to reg2. | | Bcond | disp9 | III | - | - | - | _ | _ | Conditional branch (if Carry). Tests a condition flag specified by an instruction. Branches if a specified condition is satisfied; otherwise, executes the next instruction. The branch destination PC holds the sum of the current PC value and 9-bit displacement which is the 8-bit immediate shifted 1 bit and sign-extended to word length. | | CLR1 | bit#3, disp16 [reg1] | VIII | - | - | - | * | - | Bit clear. Adds the data of reg1 to 16-bit displacement, sign-extended to word length, to generate a 32-bit address. Then clears the bit, specified by the instruction bit field, of the byte data referenced by the generated address. | | CMP | reg1, reg2 | I | * | * | * | * | - | Compare. Compares the word data of reg2 with the word data of reg1, and indicates the result by using the condition flags. To compare, the contents of reg1 are subtracted from the word data of reg2. | | СМР | imm5, reg2 | II | * | * | * | * | _ | Compare. Compares the word data of reg2 with the 5-bit immediate data, sign-extended to word length, and indicates the result by using the condition flags. To compare, the contents of the sign-extended immediate data are subtracted from the word data of reg2. | | DI | - | X | _ | - | - | - | _ | Disables maskable interrupt. Sets the ID flag of the PSW to 1 to disable the acknowledgement of maskable interrupts from acceptance; interrupts are immediately disabled at the start of this instruction execution. | Table A-1. Instruction Mnemonic (in alphabetical order) (2/7) | Instruction<br>Mnemonic | Operand | Format | CY | OV | S | Z | SAT | Instruction Function | |-------------------------|---------------------|--------|----|----|---|---|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | DIVH | reg1, reg2 | I | _ | * | * | * | _ | Signed divide. Divides the word data of reg2 by the lower half-word data of reg1, and stores the quotient to reg2. | | EI | - | Χ | - | - | - | - | - | Enables maskable interrupt. Resets the ID flag of the PSW to 0 and enables the acknowledgement of maskable interrupts at the beginning of next instruction. | | HALT | _ | Х | - | - | - | - | - | CPU halt. Stops the operating clock of the CPU and places the CPU in the HALT mode. | | JARL | disp22, reg2 | V | _ | - | - | - | _ | Jump and register link. Saves the current PC value plus 4 to general register reg2, adds a 22-bit displacement, sign-extended to word length, to the current PC value, and transfers control to the PC. Bit 0 of the 22-bit displacement is masked to 0. | | JMP | [reg1] | I | - | - | - | - | - | Register indirect unconditional branch. Transfers control to the address specified by reg1. Bit 0 of the address is masked to 0. | | JR | disp22 | V | _ | - | - | _ | _ | Unconditional branch. Adds a 22-bit displacement, sign-extended to word length, to the current PC value, and transfers control to the PC. Bit 0 of the 22-bit displacement is masked to 0. | | LD.B | disp16 [reg1], reg2 | · VII | _ | - | - | _ | _ | Byte load. Adds the data of reg1 to a 16-bit displacement, sign-extended to word length, to generate a 32-bit address. Byte data is read from the generated address, sign-extended to word length, and then stored to reg2. | | LD.H | disp16 [reg1], reg2 | · VII | - | - | - | - | _ | Half-word load. Adds the data of reg1 to a 16-bit displacement, sign-extended to word length, to generate a 32-bit address. Half-word data is read from this 32-bit address with its bit 0 masked to 0, sign-extended to word length, and stored to reg2. | | LD.W | disp16 [reg1], reg2 | . VII | _ | - | - | - | _ | Word load. Adds the data of reg1 to a 16-bit displacement, sign-extended to word length, to generate a 32-bit address. Word data is read from this 32-bit address with bits 0 and 1 masked to 0, and stored to reg2. | Table A-1. Instruction Mnemonic (in alphabetical order) (3/7) | Instruction<br>Mnemonic | Operand | Format | CY | OV | S | Z | SAT | Instruction Function | |-------------------------|----------------------|--------|----|----|---|---|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | LDSR | reg2, regID | IX | - | - | - | _ | - | Load to system register. Set the word data of reg2 to a system register specified by regID. If regID is PSW, the values of the corresponding bits of reg2 are set to the respective flags of the PSW. | | MOV | reg1, reg2 | I | - | - | - | - | _ | Moves data. Transfers the word data of reg1 to reg2. | | MOV | imm5, reg2 | II | - | - | - | - | - | Moves data. Transfers the value of a 5-bit immediate data,sign-extended to word length, to reg2. | | MOVEA | imm16, reg1, reg2 | . VI | - | - | - | - | - | Moves effective address. Adds a 16-bit immediate data, sign-extended to word length, to the word data of reg1, and stores the result to reg2. | | MOVHI | imm16, reg1, reg2 | . VI | _ | - | _ | _ | - | Moves higher half-word. Adds word data, in which the higher 16 bits are defined by the 16-bit immediate data while the lower 16 bits are set to 0, to the word data of reg1 and stores the result to reg2. | | MULH | reg1, reg2 | I | - | - | - | - | - | Signed multiply. Multiplies the lower half-word data of reg2 by the lower half-word data of reg1, and stores the result to reg2 as word data. | | MULH | imm5, reg2 | II | - | - | - | - | - | Signed multiply. Multiplies the lower half-word data of reg2 by a 5-bit immediate data, sign-extended to half-word length, and stores the result to reg2 as word data. | | MULHI | imm16, reg1, reg2 | . VI | - | - | _ | - | - | Signed multiply. Multiplies the lower half-word data of reg1 by a 16-bit immediate data, and stores the result to reg2. | | NOP | _ | I | - | - | - | - | - | No operation. Executes nothing and consumes at least one clock cycle. | | NOT | reg1, reg2 | ı | - | 0 | * | * | - | Logical Not. Logically negates (takes 1's complement of) the word data of reg1, and stores the result to reg2. | | NOT1 | bit#3, disp16 [reg1] | VIII | - | - | - | * | - | Bit not. First, adds the data of reg1 to a 16-bit displacement, sign-extended to word length, to generate a 32-bit address. The bit specified by the 3-bit field "bbb" is inverted at the byte data location referenced by the generated address. | | OR | reg1, reg2 | I | - | 0 | * | * | _ | Logical sum. ORs the word data of reg2 with the word data of reg1, and stores the result to reg2. | Table A-1. Instruction Mnemonic (in alphabetical order) (4/7) | Instruction<br>Mnemonic | Operand | Format | CY | OV | S | Z | SAT | Instruction Function | |-------------------------|-------------------|--------|----|----|---|---|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ORI | imm16, reg1, reg2 | VI | - | 0 | * | * | _ | Logical sum. ORs the word data of reg1 with the 16-bit immediate data, zero-extended to word length, and stores the result to reg2. | | RETI | - | X | * | * | * | * | * | Returns from exception or interrupt routine. Restores the return PC and PSW from the appropriate system register, and returns from exception or interrupt routine. | | SAR | reg1, reg2 | IX | * | 0 | * | * | _ | Arithmetic right shift. Arithmetically shifts the word data of reg2 to the right by 'n' positions, where 'n' is specified by the lower 5 bits of reg1 (the MSB prior to shift execution is copied and set as the new MSB), and then writes the result to reg2. | | SAR | imm5, reg2 | II | * | 0 | * | * | - | Arithmetic right shift. Arithmetically shifts the word data of reg2 to the right by 'n' positions specified by the 5-bit immediate data, zero-extended to word length (the MSB prior to shift execution is copied and set as the new MSB), and then writes the result to reg2. | | SATADD | reg1, reg2 | I | * | * | * | * | * | Saturated add. Adds the word data of reg1 to the word data of reg2, and stores the result to reg2. However, if the result exceeds the maximum positive value, the maximum positive value is stored to reg2; if the result exceeds the maximum negative value, the maximum negative value is stored to reg2. The SAT flag is set to 1. | | SATADD | imm5, reg2 | II | * | * | * | * | * | Saturated add. Adds the 5-bit immediate data, sign-extended to word length, to the word data of reg2, and stores the result to general register reg2. However, if the result exceeds the positive maximum value, the maximum positive value is stored to reg2; if the result exceeds the maximum negative value, the maximum negative value is stored to reg2. The SAT flag is set to 1. | | SATSUB | reg1, reg2 | I | * | * | * | * | * | Saturated subtract. Subtracts the word data of reg1 from the word data of reg2, and stores the result to reg2. However, if the result exceeds the maximum positive value, the maximum positive value is stored to reg2; if the result exceeds the maximum negative value, the maximum negative value is stored to reg2. The SAT flag is set to 1. | Table A-1. Instruction Mnemonic (in alphabetical order) (5/7) | Instruction<br>Mnemonic | Operand | Format | CY | OV | S | Z | SAT | Instruction Function | |-------------------------|----------------------|--------|----|----|---|---|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SATSUBI | imm16, reg1, reg2 | VI | * | * | * | * | * | Saturated subtract. Subtracts a 16-bit immediate sign-extended to word length from the word data of reg1, and stores the result to reg2. However, if the result exceeds the maximum positive value, the maximum positive value is stored to reg2; if the result exceeds the maximum negative value, the maximum negative value is stored to reg2. The SAT flag is set to 1. | | SATSUBR | reg1, reg2 | I | * | * | * | * | * | Saturated subtract reverse. Subtracts the word data of reg2 from the word data of reg1, and stores the result to reg2. However, if the result exceeds the maximum positive value, the maximum positive value is stored to reg2; if the result exceeds the maximum negative value, the maximum negative value is stored to reg2. The SAT flag is set to 1. | | SETF | cccc, reg2 | IX | _ | - | - | - | - | Set flag condition. The reg2 is set to 1 if a condition specified by condition code "cccc" is satisfied; otherwise, a 0 is stored to the register. | | SET1 | bit#3, disp16 [reg1] | VIII | _ | - | _ | * | _ | <u>Bit set</u> . First, adds a 16-bit displacement, sign-<br>extended to word length, to the data of reg1 to<br>generate a 32-bit address. The bits, specified by<br>the 3-bit bit field "bbb" is set at the byte data<br>location specified by the generated address. | | SHL | reg1, reg2 | IX | * | 0 | * | * | - | Logical left shift. Logically shifts the word data of reg2 to the left by 'n' positions (0 is shifted to the LSB side), where 'n' is specified by the lower 5 bits of reg1, and writes the result to reg2. | | SHL | imm5, reg2 | II | * | 0 | * | * | - | Logical left shift. Logically shifts the word data of reg2 to the left by 'n' positions (0 is shifted to the LSB side), where 'n' is specified by a 5-bit immediate data, zero-extended to word length, and writes the result to reg2. | | SHR | reg1, reg2 | IX | * | 0 | * | * | - | Logical right shift. Logically shifts the word data of reg2 to the right by 'n' positions (0 is shifted to the MSB side), where 'n' is specified by the lower 5 bits of reg1, and writes the result to reg2. | | SHR | imm5, reg2 | II | * | 0 | * | * | - | Logical right shift. Logically shifts the word data of reg2 to the right by 'n' positions (0 is shifted to the MSB side), where 'n' is specified by a 5-bit immediate data, zero-extended to word length, and writes the result to reg2. | Table A-1. Instruction Mnemonic (in alphabetical order) (6/7) | Instruction<br>Mnemonic | Operand | Format | CY | OV | S | Z | SAT | Instruction Function | |-------------------------|---------------------|--------|----|----|---|---|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SLD.B | disp7 [ep], reg2 | IV | - | - | - | _ | - | Byte load. Adds the 7-bit displacement, zero-extended to word length, to the element pointer to generate a 32-bit address. Byte data is read from the generated address, sign-extended to word length, and stored to reg2. | | SLD.H | disp8 [ep], reg2 | IV | - | _ | _ | - | - | Half-word load. Adds the 8-bit displacement, zero-extended to word length, to the element pointer to generate a 32-bit address. Half-word data is read from this 32-bit address with bit 0 masked to 0, sign-extended to word length, and stored to reg2. | | SLD.W | disp8 [ep], reg2 | IV | - | - | - | - | - | Word load. Adds the 8-bit displacement, zero-extended to word length, to the element pointer to generate a 32-bit address. Word data is read from this 32-bit address with bits 0 and 1 masked to 0, and stored to reg2. | | SST.B | reg2, disp7 [ep] | IV | - | - | - | - | - | Byte store. Adds the 7-bit displacement, zero-extended to word length, to the element pointer to generate a 32-bit address, and stores the data of the lowest byte of reg2 to the generated address. | | SST.H | reg2, disp8 [ep] | IV | - | _ | _ | _ | - | Half-word store. Adds the 8-bit displacement, zero-extended to word length, to the element pointer to generate a 32-bit address, and stores the lower half-word of reg2 to the generated 32-bit address with bit 0 masked to 0. | | SST.W | reg2, disp8 [ep] | IV | - | - | - | - | - | Word store. Adds the 8-bit displacement, zero-extended to word length, to the element pointer to generate a 32-bit address, and stores the word data of reg2 to the generated 32-bit address with bits 0 and 1 masked to 0. | | ST.B | reg2, disp16 [reg1] | VII | - | - | - | _ | - | Byte store. Adds the 16-bit displacement, sign-<br>extended to word length, to the data of reg1 to<br>generate a 32-bit address, and stores the lowest<br>byte data of reg2 to the generated address. | | ST.H | reg2, disp16 [reg1] | VII | - | - | - | _ | - | Half-word store. Adds the 16-bit displacement, sign-extended to word length, to the data of reg1 to generate a 32-bit address, and stores the lower half-word of reg2 to the generated 32-bit address with bit 0 masked to 0. | Table A-1. Instruction Mnemonic (in alphabetical order) (7/7) | Instruction<br>Mnemonic | Operand | Format | CY | OV | S | Z | SAT | Instruction Function | |-------------------------|----------------------|--------|----|----|---|---|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ST.W | reg2, disp16 [reg1] | VII | _ | - | _ | - | - | Word store. Adds the 16-bit displacement, sign-<br>extended to word length, to the data of reg1 to<br>generate a 32-bit address, and stores the word<br>data of reg2 to the generated 32-bit address with<br>bits 0 and 1 masked to 0. | | STSR | regID, reg2 | IX | - | - | - | - | - | Stores contents of system register. Stores the contents of a system register specified by regID to reg2. | | SUB | reg1, reg2 | I | * | * | * | * | - | Subtract. Subtracts the word data of reg1 from the word data of reg2, and stores the result to reg2. | | SUBR | reg1, reg2 | I | * | * | * | * | - | Subtract reverse. Subtracts the word data of reg2 from the word data of reg1, and stores the result to reg2. | | TRAP | vector | X | _ | - | - | - | _ | Software trap. Saves the return PC and PSW to EIPC and EIPSW, respectively; sets the exception code (EICC of ECR) and the flags of the PSW (EP and ID flags); jumps to the address of the trap handler corresponding to the trap vector specified by vector number (0 to 31), and starts exception processing. | | TST | reg1, reg2 | I | - | 0 | * | * | - | Test. ANDs the word data of reg2 with the word data of reg1. The result is not stored, and only the flags are changed. | | TST1 | bit#3, disp16 [reg1] | VIII | - | - | - | * | - | Bit test. Adds the data of reg1 to a 16-bit displacement, sign-extended to word length, to generate a 32-bit address. Performs the test on the bit, specified by the 3-bit field "bbb", at the byte data location referenced by the generated address. If the specified bit is 0, the Z flag is set to 1; if the bit is 1, the Z flag is reset to 0. The byte data, including the specified bit, is not affected. | | XOR | reg1, reg2 | I | _ | 0 | * | * | - | Exclusive OR. Exclusively ORs the word data of reg2 with the word data of reg1, and stores the result to reg2. | | XORI | imm16, reg1, reg2 | VI | - | 0 | * | * | - | Exclusive OR immediate. Exclusively ORs the word data of reg1 with a 16-bit immediate data, zero-extended to word length, and stores the result to reg2. | # APPENDIX B INSTRUCTION LIST Table B-1. Mnemonic List | Mnemonic | Function | Mnemonic | Function | |--------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Load/store | | (3-operand) | | LD.B<br>LD.H<br>LD.W<br>SLD.B<br>SLD.H<br>SLD.W<br>ST.B | Load Byte Load Halfword Lord Word Load Byte Load Halfword Load Word Store Byte Store Halfword | MOVHI<br>MOVEA<br>ADDI<br>MULHI<br>SATSUBI<br>ORI<br>ANDI<br>XORI | Move High Halfword Move Effective Address Add Immediate Multiply Halfword Immediate Saturated Subtract Immediate Or Immediate And Immediate Exclusive Or Immediate | | ST.W<br>SST.B<br>SST.H<br>SST.W | Store Word Store Byte Store Halfword Store Word Integer arithmetic operation/logical operation/saturated operation | JMP<br>JR<br>- JARL<br>Bcond | Branch Jump Register Jump Relative Jump and Register Link Branch on Condition Code | | MOV<br>ADD<br>SUB<br>SUBR | (2-operand register) Move Add Subtract Subtract Reverse | SET1<br>CLR1<br>NOT1<br>TST1 | Bit manipulation Set Bit Clear Bit Not Bit Test Bit | | MULH DIVH CMP SATADD SATSUB SATSUBR TST OR AND XOR NOT SHL SHR SAR | Multiply Halfword Divide Halfword Compare Saturated Add Saturated Subtract Saturated Subtract Reverse Test Or And Exclusive Or Not Shift Logical Left Shift Arithmetic Right (2-operand immediate) | LDSR<br>STSR<br>TRAP<br>RETI<br>HALT<br>DI<br>EI<br>NOP | Special Load System Register Store System Register Trap Return from Trap or Interrupt Halt Disable Interrupt Enable Interrupt No Operation | | MOV<br>ADD<br>CMP<br>SATADD<br>SETF<br>SHL<br>SHR<br>SAR | (2-operand immediate) Move Add Compare Saturated Add Set Flag Condition Shift Logical Left Shift Logical Right Shift Arithmetic Right | | | Table B-2. Instruction Set | Instruction Code | Instru | ction Format | Format | Remarks | |-------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|---------------------------| | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 1 1 0 0 0 0 0 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | MOV<br>NOT<br>DIVH<br>JMP<br>SATSUBR<br>SATADD<br>MULH<br>OR<br>XOR<br>AND<br>TST<br>SUBR<br>SUB<br>ADD<br>CMP | reg1, reg2 reg1, reg2 reg1, reg2 [reg1] reg1, reg2 | ſ | When reg1, reg2 = 0, NOP | | 0 1 0 0 0 0<br>0 1 0 0 0 1<br>0 1 0 0 0 1<br>0 1 0 0 1 0<br>0 1 0 0 1 1<br>0 1 0 1 | MOV<br>SATADD<br>ADD<br>CMP<br>SHR<br>SAR<br>SHL<br>MULH | imm5, reg2<br>imm5, reg2<br>imm5, reg2<br>imm5, reg2<br>imm5, reg2<br>imm5, reg2<br>imm5, reg2<br>imm5, reg2 | II | | | 0 1 1 0 x x<br>0 1 1 1 x x<br>1 0 0 0 x x<br>1 0 0 1 x x<br>1 0 1 0 x x<br>1 0 1 0 x x | SLD.B<br>SST.B<br>SLD.H<br>SST.H<br>SLD.W<br>SST.W | disp7 [ep], reg2<br>reg2, disp7 [ep]<br>disp8 [ep], reg2<br>reg2, disp8 [ep]<br>disp8 [ep], reg2<br>reg2, disp8 [ep] | IV | | | 1 0 1 1 × × 1 1 0 0 0 0 1 1 0 0 0 1 1 1 0 0 1 0 1 1 0 0 1 1 1 1 0 1 0 | Bcond ADDI MOVEA MOVHI SATSUBI ORI XORI ANDI MULHI | disp9 imm16, reg1, reg2 | III<br>VI | | | 1 1 1 0 0 0<br>1 1 1 0 0 1<br>1 1 1 0 1 0<br>1 1 1 0 1 0 | LD.B<br>LD.H<br>LD.W<br>ST.B<br>ST.H<br>ST.W | disp16 [reg1], reg2<br>disp16 [reg1], reg2<br>disp16 [reg1], reg2<br>reg2, disp16 [reg1]<br>reg2, disp16 [reg1]<br>reg2, disp16 [reg1] | VII | | | 1 1 1 1 0 × | JARL | disp22, reg2 | V | When reg2 = r0, JR disp22 | | 1 1 1 1 1 0<br>1 1 1 1 1 0<br>1 1 1 1 1 0<br>1 1 1 1 | SET1<br>CLR1<br>NOT1<br>TST1 | bit#3, disp16 [reg1]<br>bit#3, disp16 [reg1]<br>bit#3, disp16 [reg1]<br>bit#3, disp16 [reg1] | VIII | | | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | SETF<br>LDSR<br>STSR<br>SHR<br>SAR<br>SHL | cccc, reg2<br>reg2, regID<br>regID, reg2<br>reg1, reg2<br>reg1, reg2<br>reg1, reg2 | IX | | | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | TRAP HALT RETI DI EI Undefined instru | vector | Х | | # APPENDIX C INSTRUCTION OP CODE MAP The following tables (a) through (f) show the op code maps corresponding to instruction codes. # Instruction code #### • 16-bit instruction format # • 32-bit instruction format # (a) Op code | Bits 6 - 5 | 00 | 01 | 10 | 11 | Format | |------------|-------------|-----------------------------|-------------------------|-----------------------------|-----------------| | 0000 | MOV/NOP | NOT | DIVH | JMP | I | | 0001 | SATSUBR | SATSUB | SATADD | MULH | | | 0010 | OR | XOR | AND | | | | 0011 | SUBR | SUB | ADD R, r | CMP R,r | | | 0100 | MOV imm5, r | SATADD | ADD imm5, r | CMP imm5, r | II | | 0101 | SHR imm5, r | SAR imm5, r | SHL imm5, r | MULH | | | 0110 | | IV | | | | | 0111 | | | | | | | 1000 | | SL | D.H | | | | 1001 | | SS | T.H | | | | 1010 | | SLD. W/S | SST.W <sup>Note 1</sup> | | | | 1011 | | Вс | ond | | III | | 1100 | ADDI | MOVEA | MOVHI | SATSUBI | VI | | 1101 | ORI | XORI | ANDI | ANDI MULHI | | | 1110 | LD.B | LD.H/LD.W <sup>Note 2</sup> | ST.B | ST.H/ST.W <sup>Note 2</sup> | V/VII/VIII/IX/X | | 1111 | JA | RL | Bit manipulationNote 3 | Extension 1Note 4 | | Notes 1. Refer to (b). - 2. Refer to (c). - 3. Refer to (d). - 4. Refer to (e). # (b) Short format load/store instruction (displacement/sub-op code) | Bit 0<br>Bits 10 - 7 | 0 | 1 | | | | | |----------------------|-------|-------|--|--|--|--| | 0110 | SLD.B | | | | | | | 0111 | SST.B | | | | | | | 1000 | SLD.H | | | | | | | 1001 | SST.H | | | | | | | 1010 | SLD.W | SST.W | | | | | # (c) Load/store instruction (displacement/sub-op code) | Bit 16 Bits 6 - 5 | 0 | 1 | | |-------------------|------|------|--| | 00 | LC | ).B | | | 01 | LD.H | LD.W | | | 10 | ST.B | | | | 11 | ST.H | ST.W | | # (d) Bit manipulation instruction (sub-op code) | Bit 14 | 0 | 1 | |--------|------|------| | Bit 15 | | | | 0 | SET1 | NOT1 | | 1 | CLR1 | TST1 | # (e) Extension 1 (sub-op code) | Bits 22 - 21<br>Bits 26 - 23 | 00 | 01 | 10 | 11 | |------------------------------|---------------------|----------|----------|-----------------------------| | 0000 | SETF | LDSR | STSR | Undefined | | 0001 | SHR R, r | SAR R, r | SHL R, r | Undefined | | 0010 | TRAP | HALT | RETI | Extension 2 <sup>Note</sup> | | 0011 | | | | | | ≀ | Illegal instruction | | | | | 1111 | | | | | Note Refer to (f). # (f) Extension 2 (sub-op code) | Bits 14 - 13 | 00 | 01 | 10 | 11 | |--------------|----|----|-----------|----| | 0 | DI | | Undefined | | | 1 | EI | | | | # **INDEX** | Addressing Modes | ADD | 36 | |--------------------------|--------|----| | Operand Address22 | ADDI | 37 | | Based Addressing22 | AND | 38 | | Bit Addressing24 | ANDI | 39 | | Immediate Addressing22 | Bcond | 40 | | Register Addressing22 | CLR1 | 42 | | Instruction Address19 | CMP | 43 | | Register Addressing21 | DI | 44 | | Relative Addressing19 | DIVH | 45 | | Data Format | El | 46 | | Alignment15 | HALT | 47 | | Representation14 | JARL | 48 | | Types13 | JMP | 49 | | Execution clock92 | JR | 50 | | Instruction Format | LD | 51 | | 3-operand26 | LDSR | 53 | | 16-bit load/store26 | MOV | 54 | | 32-bit load/store26 | MOVEA | 55 | | Bit manipulation27 | MOVHI | 56 | | Conditional branch25 | MULH | 57 | | Extended format27 | MULHI | 58 | | imm-reg25 | NOP | 59 | | Jump26 | NOT | 60 | | reg-reg25 | NOT1 | 61 | | Memory Map18 | OR | 62 | | Program Registers6 | ORI | 63 | | Program Status Word9 | RETI | 64 | | System Registers8 | SAR | 66 | | System Register Number11 | SATADD | 67 | | | SATSUB | 68 | | SATSUBI69 | |-----------| | SATSUBR70 | | SETF71 | | SET173 | | SHL74 | | SHR75 | | SLD76 | | SST78 | | ST80 | | STSR82 | | SUB83 | | SUBR84 | | TRAP85 | | TST86 | | TST187 | | XOR88 | | XORI89 | # Facsimile Message Although NEC has taken all possible steps to ensure that the documentation supplied to our customers is complete, bug free Organization | From: Name | | | to our customers is complete, bug free<br>and up-to-date, we readily accept that<br>errors may occur. Despite all the care and<br>precautions we've taken, you may<br>encounter problems in the documentation.<br>Please complete this form whenever | | | |------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|------| | | | | | | | | Tel. | FAX | | | | | | Address | | | Thank you for yo | our kind supp | ort | | | | | Thank you for yo | иг кина ѕирр | OII. | | North America<br>NEC Electronics Inc.<br>Corporate Communications Dept.<br>Fax: 1-800-729-9288 | Hong Kong, Philippines NEC Electronics Hong K Fax: +852-2886-9022/90 | ong Ltd. | Asian Nations except Philippines NEC Electronics Singapore Pte. Ltd. Fax: +65-250-3583 | | | | Europe NEC Electronics (Europe) GmbH Technical Documentation Dept. Fax: +49-211-6503-274 | Korea<br>NEC Electronics Hong K<br>Seoul Branch<br>Fax: 02-528-4411 | ong Ltd. | Japan NEC Corporation Semiconductor Solution Engineering Division Technical Information Support Dept. Fax: 044-548-7900 | | sion | | South America<br>NEC do Brasil S.A.<br>Fax: +55-11-889-1689 | <b>Taiwan</b> NEC Electronics Taiwan Fax: 02-719-5951 | Ltd. | rax. 044-340-7900 | | | | would like to report the follow | wing error/make the fo | ollowing su | ggestion: | | | | Oocument title: | | · · | | | | | Document number: | | | Page number: | | | | | | | | | | | | | | | | | | | | | | | | | f possible, please fax the refe | erenced page or draw | ving. | | | | | <b>Document Rating</b> | Excellent ( | Good | Acceptable | Poor | | | Clarity | | | | 0 | | | Technical Accuracy | | | | | |