**User's Manual** 



# **V850ES**

# **32-Bit Microprocessor Core**

Architecture

Document No. U15943EJ2V0UM00 (2nd edition) Date Published September 2002 N CP(K)

© NEC Corporation 2002 Printed in Japan [MEMO]

# **①** 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.

V850 Series, V850ES/KF1, V850ES/KG1, V850ES/KJ1, V850ES/SA2, and V850ES/SA3 are trademarks of NEC Corporation.

Windows is either a registered trademark or a trademark of Microsoft Corporation in the United States and/or other countries.

Purchase of NEC I<sup>2</sup>C components conveys a license under the Philips I<sup>2</sup>C Patent Rights to use these components in an I<sup>2</sup>C system, provided that the system conforms to the I<sup>2</sup>C Standard Specification as defined by Philips.

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 current as of July, 2002. The information is subject to change without notice. For actual design-in, refer to the latest publications of NEC's data sheets or data books, etc., for the most up-to-date specifications of NEC semiconductor products. Not all products and/or types are available in every country. Please check with an NEC sales representative for availability and additional information.
- No part of this document may be copied or reproduced in any form or by any means without prior written consent of NEC. NEC assumes no responsibility for any errors that may appear in this document.
- NEC does not assume any liability for infringement of patents, copyrights or other intellectual property rights of third parties by or arising from the use of NEC semiconductor products listed in this document or any other liability arising from the use of such products. No license, express, implied or otherwise, is granted under any patents, copyrights or other intellectual property rights of NEC or others.
- Descriptions of circuits, software and other related information in this document are provided for illustrative purposes in semiconductor product operation and application examples. The incorporation of these circuits, software and information in the design of customer's equipment shall be done under the full responsibility of customer. NEC assumes no responsibility for any losses incurred by customers or third parties arising from the use of these circuits, software and information.
- While NEC endeavours to enhance the quality, reliability and safety of NEC semiconductor products, customers
  agree and acknowledge that the possibility of defects thereof cannot be eliminated entirely. To minimize
  risks of damage to property or injury (including death) to persons arising from defects in NEC
  semiconductor products, customers must incorporate sufficient safety measures in their design, such as
  redundancy, fire-containment, and anti-failure features.
- NEC semiconductor products are classified into the following three quality grades:
   "Standard", "Special" and "Specific". The "Specific" quality grade applies only to semiconductor products
   developed based on a customer-designated "quality assurance program" for a specific application. The
   recommended applications of a semiconductor product depend on its quality grade, as indicated below.
   Customers must check the quality grade of each semiconductor product 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": Aircraft, aerospace equipment, submersible repeaters, nuclear reactor control systems, life support systems and medical equipment for life support, etc.

The quality grade of NEC semiconductor products is "Standard" unless otherwise expressly specified in NEC's data sheets or data books, etc. If customers wish to use NEC semiconductor products in applications not intended by NEC, they must contact an NEC sales representative in advance to determine NEC's willingness to support a given application.

(Note)

- (1) "NEC" as used in this statement means NEC Corporation and also includes its majority-owned subsidiaries.
- (2) "NEC semiconductor products" means any semiconductor product developed or manufactured by or for NEC (as defined above).

M8E 00.4

# **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.)

Santa Clara, California Tel: 408-588-6000 800-366-9782 Fax: 408-588-6130 800-729-9288

#### NEC do Brasil S.A.

Electron Devices Division Guarulhos-SP, Brasil Tel: 11-6462-6810 Fax: 11-6462-6829

# NEC Electronics (Europe) GmbH

Duesseldorf, Germany Tel: 0211-65 03 01 Fax: 0211-65 03 327

- Sucursal en España Madrid, Spain Tel: 091-504 27 87 Fax: 091-504 28 60
- Succursale Française Vélizy-Villacoublay, France Tel: 01-30-67 58 00 Fax: 01-30-67 58 99

- Filiale Italiana Milano, Italy Tel: 02-66 75 41 Fax: 02-66 75 42 99
- Branch The Netherlands Eindhoven, The Netherlands Tel: 040-244 58 45 Fax: 040-244 45 80
- Branch Sweden Taeby, Sweden Tel: 08-63 80 820 Fax: 08-63 80 388
- United Kingdom Branch Milton Keynes, UK Tel: 01908-691-133 Fax: 01908-670-290

#### 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 Shanghai, Ltd.

Shanghai, P.R. China Tel: 021-6841-1138 Fax: 021-6841-1137

#### **NEC Electronics Taiwan Ltd.**

Taipei, Taiwan Tel: 02-2719-2377 Fax: 02-2719-5951

#### NEC Electronics Singapore Pte. Ltd.

Novena Square, Singapore Tel: 253-8311 Fax: 250-3583

J02.4

# Major Revisions in This Edition

| Page  | Description                                                                                                     |  |
|-------|-----------------------------------------------------------------------------------------------------------------|--|
| p.16  | Modification of description of V850ES CPU core in Figure 1-1 V850 Series CPU Development                        |  |
| p.83  | Addition of description of Caution in 5.3 Instruction Set MUL                                                   |  |
| p.86  | Addition of description of Caution in 5.3 Instruction Set MULU                                                  |  |
| p.190 | Modification of description of pipeline in APPENDIX C DIFFERENCES IN ARCHITECTURE OF V850 CPU<br>AND V850E1 CPU |  |
| p.196 | Addition of APPENDIX F REVISION HISTORY                                                                         |  |

The mark  $\star$  shows major revised points.

# PREFACE

| Target Readers         |                                                                                                                                                                              | users who wish to understand the functions of the V850ES plication systems using the V850ES CPU core.                                                                                                                                                                                                              |
|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                        | <ul> <li>V850ES/SA3<sup>™</sup>: μI</li> <li>V850ES/KF1<sup>™</sup>: μI</li> <li>70</li> <li>V850ES/KG1<sup>™</sup>: μI</li> <li>70</li> </ul>                               | g V850ES CPU core<br>PD703201, 703201Y, 70F3201, 70F3201Y<br>PD703204, 703204Y, 70F3204, 70F3204Y<br>PD703208, 703208Y, 703209, 703209Y, 703210, 703210Y,<br>DF3210, 70F3210Y<br>PD703212, 703212Y, 703213, 703213Y, 703214, 703214Y,<br>DF3214, 70F3214Y<br>PD703216, 703216Y, 703217, 703217Y, 70F3217, 70F3217Y |
| Purpose                |                                                                                                                                                                              | o give users an understanding of the architecture of the ed in the <b>Organization</b> below.                                                                                                                                                                                                                      |
| Organization           | <ul> <li>This manual contains the for</li> <li>Register set</li> <li>Data type</li> <li>Instruction format and</li> <li>Interrupt and exception</li> <li>Pipeline</li> </ul> | d instruction set                                                                                                                                                                                                                                                                                                  |
| How to Use this Manual |                                                                                                                                                                              | der of this manual has general knowledge in the fields of circuits, and microcontrollers.                                                                                                                                                                                                                          |
|                        | To learn about the hardwar<br>→ Read <b>Hardware Use</b>                                                                                                                     | e functions,<br>e <b>r's Manual</b> of each product.                                                                                                                                                                                                                                                               |
|                        | To learn about the functions<br>→ Read CHAPTER 5 IN                                                                                                                          | s of a specific instruction in detail,<br>NSTRUCTION.                                                                                                                                                                                                                                                              |
| Conventions            | Data significance:<br>Active low representation:<br><b>Note</b> :<br><b>Caution</b> :<br><b>Remark</b> :<br>Numerical representation:                                        | Higher digits on the left and lower digits on the right<br>×××B (B is appended to pin or signal name)<br>Footnote for item marked with <b>Note</b> in the text<br>Information requiring particular attention<br>Supplementary information<br>Binary ×××× or ××××B<br>Decimal ××××<br>Hexadecimal ××××H             |
|                        | Prefix indicating the power                                                                                                                                                  | of 2 (address space, memory capacity):<br>K (Kilo): $2^{10} = 1,024$<br>M (Mega): $2^{20} = 1,024^2$<br>G (Giga): $2^{30} = 1,024^3$                                                                                                                                                                               |

The related documents indicated in this publication may include preliminary versions. However, preliminary versions are not marked as such.

# • Documents related to devices

| Document Name                                             | Document No. |
|-----------------------------------------------------------|--------------|
| V850ES/SA2, V850ES/SA3 Hardware User's Manual             | U15905E      |
| V850ES/KF1, V850ES/KG1, V850ES/KJ1 Hardware User's Manual | U15862E      |

#### • Documents related to development tools

| Document Name                                                              | Document No.                                                                               |                |  |
|----------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|----------------|--|
| IE-V850ES-G1 (In-Circuit Emulator)                                         | To be prepared                                                                             |                |  |
| IE-703204-G1-EM1 (In-Circuit Emulator Option Bo<br>V850ES/SA3)             | ard for V850ES/SA2,                                                                        | To be prepared |  |
| IE-703217-G1-EM1 (In-Circuit Emulator Option Bo<br>V850ES/KG1, V850ES/KJ1) | IE-703217-G1-EM1 (In-Circuit Emulator Option Board for V850ES/KF1, V850ES/KG1, V850ES/KJ1) |                |  |
| CA850 (Ver. 2.40 or Later) (C Compiler Package)                            | Operation                                                                                  | U15024E        |  |
|                                                                            | C Language                                                                                 | U15025E        |  |
|                                                                            | Project Manager                                                                            | U15026E        |  |
|                                                                            | Assembly Language                                                                          | U15027E        |  |
| ID850 (Ver. 2.40) (Integrated Debugger)                                    | Operation<br>Windows <sup>™</sup> Based                                                    | U15181E        |  |
| RX850 (Ver. 3.13 or Later) (Real-Time OS)                                  | Fundamental                                                                                | U13430E        |  |
|                                                                            | Installation                                                                               | U13410E        |  |
|                                                                            | Technical                                                                                  | U13431E        |  |
| RX850 Pro (Ver. 3.13) (Real-Time OS)                                       | Fundamental                                                                                | U13773E        |  |
|                                                                            | Installation                                                                               | U13774E        |  |
|                                                                            | Technical                                                                                  | U13772E        |  |
| RD850 (Ver. 3.01) (Task Debugger)                                          |                                                                                            | U13737E        |  |
| RD850 Pro (Ver. 3.01) (Task Debugger)                                      | U13916E                                                                                    |                |  |
| AZ850 (Ver. 3.0) (System Performance Analyzer)                             | U14410E                                                                                    |                |  |
| PG-FP3 (Flash Memory Programmer)                                           | U13502E                                                                                    |                |  |
| PG-FP4 (Flash Memory Programmer)                                           | U15260E                                                                                    |                |  |

# CONTENTS

| 1.1       Features       16         1.2       Internal Configuration       17         CHAPTER 2       REGISTER SET       18         2.1       Program Registers       20         2.2.1       Interrupt status saving registers (EIPC, EIPSW)       21         2.2.2       NMI status saving registers (EFC, FEPSW)       22         2.2.3       Exception cause register (ECR)       22         2.4       Program status word (PSW)       23         2.2.5       CALLT caller status saving registers (DBPC, DBPSW)       24         2.2.6       Exception/debug trap status saving registers (DBPC, DBPSW)       25         2.2.7       CALLT Tabse pointer (CTBP)       26         3.1       Data Format       26         3.2       Data Representation       26         3.2.1       Integer       28         3.2.2       Unsigned integer       28         3.2.3       Bit       28         3.2.4       Integer       28         3.2.3       Bit       28         CHAPTER 4       ADDRESS SPACE       29         4.1       Memory Map       30         4.2       Operand address       31         4.2.1       Instructi                                                                                         | CHAP | TER 1  | GENERAL                                                    | 15 |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|------------------------------------------------------------|----|
| 1.2       Internal Configuration       17         CHAPTER 2 REGISTER SET       18         2.1       Program Registers       20         2.2.1       Interrupt status saving registers (EIPC, EIPSW)       21         2.2.2       NMI status saving registers (EIPC, EIPSW)       21         2.2.3       Exception cause register (ECP)       22         2.2.4       Program status saving registers (EIPC, CTPSW)       22         2.2.5       CALLT caller status saving registers (DPC, DPSW)       23         2.2.6       Exception/debug trap status saving registers (DPC, DPSW)       25         2.2.7       CALLT base pointer (CTBP)       25         2.2.6       Data Format       26         3.1       Data Format       26         3.2       Data Representation       28         3.2.1       Integer       28         3.2.2       Unsigned integer       28         3.3       Data Alignment       28         3.4       2.2       Operand address         3.3       Data Alignment       28         3.4       Addressing Mode       31         4.2.1       Instruction address       31         4.2.2       Operand address       31 <tr< th=""><th>1.1</th><th>Featu</th><th>res</th><th>16</th></tr<> | 1.1  | Featu  | res                                                        | 16 |
| 2.1       Program Registers.       19         2.2       System Registers.       20         2.2.1       Interrupt status saving registers (EIPC, EIPSW)       21         2.2.2       NMI status saving registers (FEPC, FEPSW)       22         2.2.3       Exception cause register (ECP)       22         2.2.4       Program status word (PSW)       23         2.2.5       CALLT caller status saving registers (CTPC, CTPSW)       24         2.2.6       Exception/debug trag status saving registers (DBPC, DBPSW)       25         2.2.7       CALLT base pointer (CTBP)       25         CHAPTER 3 DATA TYPE       26         3.1       Data Format       26         3.2.0       Data Representation       28         3.2.1       Integer       28         3.2.2       Unsigned integer       28         3.2.3       Bit       28         3.3       Data Alignment       26         CHAPTER 4 ADDRESS SPACE       29         4.1       Memory Map       30         4.2.2       Operand address       31         4.2.2       Operand address       33         5.3       Instruction Format       35         5.4       Instruction Set                                                                       | 1.2  |        |                                                            |    |
| 2.1       Program Registers.       19         2.2       System Registers.       20         2.2.1       Interrupt status saving registers (EIPC, EIPSW)       21         2.2.2       NMI status saving registers (FEPC, FEPSW)       22         2.2.3       Exception cause register (ECP)       22         2.2.4       Program status word (PSW)       23         2.2.5       CALLT caller status saving registers (CTPC, CTPSW)       24         2.2.6       Exception/debug trag status saving registers (DBPC, DBPSW)       25         2.2.7       CALLT base pointer (CTBP)       25         CHAPTER 3 DATA TYPE       26         3.1       Data Format       26         3.2.0       Data Representation       28         3.2.1       Integer       28         3.2.2       Unsigned integer       28         3.2.3       Bit       28         3.3       Data Alignment       26         CHAPTER 4 ADDRESS SPACE       29         4.1       Memory Map       30         4.2.2       Operand address       31         4.2.2       Operand address       33         5.3       Instruction Format       35         5.4       Instruction Set                                                                       |      |        |                                                            |    |
| 2.2       System Registers.       20         2.2.1       Interrupt status saving registers (EIPC, EIPSW).       21         2.2.2       NMI status caving registers (FEPC, FEPSW).       22         2.2.3       Exception cause register (ECR).       22         2.2.4       Program status word (PSW).       23         2.2.5       CALLT caller status saving registers (CTPC, CTPSW).       24         2.2.6       Exception/debug trap status saving registers (DBPC, DBPSW).       25         2.2.7       CALLT base pointer (CTBP).       25         CHAPTER 3       DATA TYPE.       26         3.1       Data Format.       26         3.2.1       Integer       28         3.2.2       Unsigned integer       28         3.2.3       Bit       28         3.3       Data Alignment       28         3.3       Data Alignment       28         3.4       Addressing Mode       31         4.1       Memory Map       30         4.2       Operand address       31         4.2.1       Instruction address       31         4.2.2       Operand address       32         5.1       Instruction Set       39         5.2                                                                                     | CHAP | TER 2  | REGISTER SET                                               | 18 |
| 2.2       System Registers.       20         2.2.1       Interrupt status saving registers (EIPC, EIPSW).       21         2.2.2       NMI status caving registers (FEPC, FEPSW).       22         2.2.3       Exception cause register (ECR).       22         2.2.4       Program status word (PSW).       23         2.2.5       CALLT caller status saving registers (CTPC, CTPSW).       24         2.2.6       Exception/debug trap status saving registers (DBPC, DBPSW).       25         2.2.7       CALLT base pointer (CTBP).       25         CHAPTER 3       DATA TYPE.       26         3.1       Data Format.       26         3.2.1       Integer       28         3.2.2       Unsigned integer       28         3.2.3       Bit       28         3.3       Data Alignment       28         3.3       Data Alignment       28         3.4       Addressing Mode       31         4.1       Memory Map       30         4.2       Operand address       31         4.2.1       Instruction address       31         4.2.2       Operand address       32         5.1       Instruction Set       39         5.2                                                                                     | 2.1  | Proar  | am Registers                                               |    |
| 2.2.1       Interrupt status saving registers (EIPC, EIPSW)       .21         2.2.2       NMI status saving registers (ECR)       .22         2.2.3       Exception cause register (ECR)       .22         2.2.4       Program status word (PSW)       .23         2.2.5       CALLT caller status saving registers (DEPC, TPSW)       .24         2.2.6       Exception/debug trap status saving registers (DBPC, DBPSW)       .25         2.2.7       CALLT base pointer (CTBP)       .25         CHAPTER 3       DATA TYPE       .26         3.1       Data Format.       .26         3.2       Data Representation       .28         3.2.1       Integer       .28         3.2.2       Unsigned integer       .28         3.2.3       Bit       .28         3.3       Data Alignment       .28         3.4       Memory Map       .30         4.1       Memory Map       .30         4.2       Operand address       .31         4.2.2       Operand address       .31         4.2.2       Operand address       .33         5.1       Instruction Format       .35         5.1       Instruction Set       .39         5.3 <th></th> <th>-</th> <th>•</th> <th></th>                                          |      | -      | •                                                          |    |
| 2.2.2       NMI status saving register (ECR)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      | •      | •                                                          |    |
| 2.2.3       Exception cause register (ECR)       .22         2.2.4       Program status word (PSW)       .23         2.2.5       CALLT caller status saving registers (CTPC, CTPSW)       .24         2.2.6       Exception/debug trap status saving registers (DBPC, DBPSW)       .25         2.2.7       CALLT base pointer (CTBP)       .25         CHAPTER 3       DATA TYPE       .26         3.1       Data Format       .26         3.2.1       Integer       .28         3.2.2       Unsigned integer       .28         3.2.3       Bit       .28         3.2.4       Unsigned integer       .28         3.2.3       Bit       .28         3.3       Data Alignment       .28         3.3       Data Alignment       .28         3.4       Memory Map       .30         4.1       Memory Map       .30         4.2       Operand address       .31         4.2.2       Operand address       .33         5.1       Instruction Format       .35         5.2       Outline of Instructions       .39         5.3       Instruction Set       .43         ADD       .46         AND                                                                                                                          |      | 2.2.2  |                                                            |    |
| 2.2.5       CALLT caller status saving registers (CTPC, CTPSW)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |      | 2.2.3  |                                                            |    |
| 2.2.6       Exception/debug trap status saving registers (DBPC, DBPSW)       .25         2.2.7       CALLT base pointer (CTBP)       .25         CHAPTER 3 DATA TYPE       .26         3.1       Data Format       .26         3.2       Data Representation       .28         3.2.1       Integer       .28         3.2.2       Unsigned integer       .28         3.2.3       Bit       .28         3.3       Data Alignment       .28         CHAPTER 4 ADDRESS SPACE       .29         4.1       Memory Map       .30         4.2       Addressing Mode       .31         4.2.2       Operand address       .31         4.2.2       Operand address       .33         5.3       Instruction Format       .35         5.4       Instruction Set       .39         5.3       Instruction Set       .43         ADD       .45       .40         ADD       .45       .40         ADD       .45       .46         AND       .46       .47         AND       .46       .47         AND       .46       .46         AND       .46       .49 <td></td> <td>2.2.4</td> <td>Program status word (PSW)</td> <td>23</td>                                                                                                   |      | 2.2.4  | Program status word (PSW)                                  | 23 |
| 2.2.7       CALLT base pointer (CTBP)       .25         CHAPTER 3 DATA TYPE       .26         3.1       Data Format.       .26         3.2       Data Representation       .28         3.2.1       Integer       .28         3.2.2       Unsigned integer       .28         3.2.3       Bit       .28         3.3       Data Alignment       .28         3.3       Data Alignment       .28         CHAPTER 4 ADDRESS SPACE       .29         4.1       Memory Map       .30         4.2       Addressing Mode       .31         4.2.1       Instruction address       .31         4.2.2       Operand address       .33         CHAPTER 5       INSTRUCTION       .35         5.1       Instruction Format       .35         5.2       Outline of Instructions       .39         5.3       Instruction Set       .43         ADD       .45         ADD       .46         AND       .47         AND       .47         AND       .47         ADD       .45         ADD       .46         AND       .47 <t< td=""><td></td><td>2.2.5</td><td>CALLT caller status saving registers (CTPC, CTPSW)</td><td>24</td></t<>                                                                                                 |      | 2.2.5  | CALLT caller status saving registers (CTPC, CTPSW)         | 24 |
| CHAPTER 3 DATA TYPE       26         3.1 Data Format       26         3.2 Data Representation       28         3.2.1 Integer       28         3.2.2 Unsigned integer       28         3.2.3 Bit       28         3.3 Data Alignment       28         CHAPTER 4 ADDRESS SPACE       29         4.1 Memory Map       30         4.2 Addressing Mode       31         4.2.1 Instruction address       31         4.2.2 Operand address       33         CHAPTER 5 INSTRUCTION       35         5.1 Instruction Format       35         5.2 Outline of Instructions       39         5.3 Instruction Set       43         ADD       46         AND       47         AND       51         BSW <t< td=""><td></td><td>2.2.6</td><td>Exception/debug trap status saving registers (DBPC, DBPSW)</td><td>25</td></t<>                                                                                                                                          |      | 2.2.6  | Exception/debug trap status saving registers (DBPC, DBPSW) | 25 |
| 3.1       Data Format.       26         3.2       Data Representation.       28         3.2.1       Integer       28         3.2.2       Unsigned integer       28         3.2.3       Bit       28         3.3       Data Alignment       28         CHAPTER 4       ADDRESS SPACE       29         4.1       Memory Map.       30         4.2       Addressing Mode.       31         4.2.1       Instruction address       31         4.2.2       Operand address       33         CHAPTER 5       INSTRUCTION       35         5.1       Instruction Format.       35         5.2       Outline of Instructions       39         5.3       Instruction Set.       43         ADD.       45       40         ADD.       45       40         ADD.       46       47         AND.       47       48         Bcond       49       51         BSH       51       52         CALLT       53         CALLT       53         CALLT       53                                                                                                                                                                                                                                                                            |      | 2.2.7  | CALLT base pointer (CTBP)                                  | 25 |
| 3.1       Data Format.       26         3.2       Data Representation.       28         3.2.1       Integer       28         3.2.2       Unsigned integer       28         3.2.3       Bit       28         3.3       Data Alignment       28         CHAPTER 4       ADDRESS SPACE       29         4.1       Memory Map.       30         4.2       Addressing Mode.       31         4.2.1       Instruction address       31         4.2.2       Operand address       33         CHAPTER 5       INSTRUCTION       35         5.1       Instruction Format.       35         5.2       Outline of Instructions       39         5.3       Instruction Set.       43         ADD.       45       40         ADD.       45       40         ADD.       46       47         AND.       47       48         Bcond       49       51         BSH       51       52         CALLT       53         CALLT       53         CALLT       53                                                                                                                                                                                                                                                                            |      |        |                                                            |    |
| 3.2       Data Representation       28         3.2.1       Integer       28         3.2.2       Unsigned integer       28         3.2.3       Bit       28         3.3       Data Alignment       28         CHAPTER 4       ADDRESS SPACE       29         4.1       Memory Map       30         4.2       Addressing Mode       31         4.2.1       Instruction address       31         4.2.2       Operand address       33         CHAPTER 5       INSTRUCTION       35         5.1       Instruction Format       35         5.2       Outline of Instructions       39         5.3       Instruction Set       43         ADD       45       ADD         ADD       46       AND         AND       46         Boond       49         BSH       51         BSW       52         CALLT       53         CIR1       54                                                                                                                                                                                                                                                                                                                                                                                       | CHAP | TER 3  | DATA TYPE                                                  | 26 |
| 3.2       Data Representation       28         3.2.1       Integer       28         3.2.2       Unsigned integer       28         3.2.3       Bit       28         3.3       Data Alignment       28         CHAPTER 4       ADDRESS SPACE       29         4.1       Memory Map       30         4.2       Addressing Mode       31         4.2.1       Instruction address       31         4.2.2       Operand address       33         CHAPTER 5       INSTRUCTION       35         5.1       Instruction Format       35         5.2       Outline of Instructions       39         5.3       Instruction Set       43         ADD       45       ADD         ADD       46       AND         AND       46         Boond       49         BSH       51         BSW       52         CALLT       53         CIR1       54                                                                                                                                                                                                                                                                                                                                                                                       | 3.1  | Data I | Format                                                     |    |
| 3.2.1       Integer       28         3.2.2       Unsigned integer       28         3.2.3       Bit       28         3.3       Data Alignment       28         CHAPTER 4       ADDRESS SPACE       29         4.1       Memory Map       30         4.2       Addressing Mode       31         4.2.1       Instruction address       31         4.2.2       Operand address       33         CHAPTER 5       INSTRUCTION       35         5.1       Instruction Format       35         5.2       Outline of Instructions       39         5.3       Instruction Set       43         ADD       45       400         ADD       46       47         AND       47       47         AND       46       49         BSH       51       51         BSW       52       CALLT       53         CLR1       54       54                                                                                                                                                                                                                                                                                                                                                                                                       | -    |        |                                                            |    |
| 3.2.2       Unsigned integer       28         3.2.3       Bit       28         3.3       Data Alignment       28         CHAPTER 4       ADDRESS SPACE       29         4.1       Memory Map       30         4.2       Addressing Mode       31         4.2.1       Instruction address       31         4.2.2       Operand address       33         CHAPTER 5       INSTRUCTION       35         5.1       Instruction Format       35         5.2       Outline of Instructions       39         5.3       Instruction Set       43         ADD       45       40         ADD       46       47         AND       46       48         Bcond       49       51         BSW       52       CALLT       53         CLR1       53       53                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | -    |        | •                                                          |    |
| 3.3 Data Alignment       28         CHAPTER 4 ADDRESS SPACE       29         4.1 Memory Map.       30         4.2 Addressing Mode.       31         4.2.1 Instruction address       31         4.2.2 Operand address       33         CHAPTER 5 INSTRUCTION       35         5.1 Instruction Format       35         5.2 Outline of Instructions       39         5.3 Instruction Set       43         ADD       45         ADD       46         AND       47         AND       47         BSH       51         BSW       52         CALLT       53         CLR1       54                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      | 3.2.2  | •                                                          |    |
| CHAPTER 4 ADDRESS SPACE       29         4.1 Memory Map       30         4.2 Addressing Mode       31         4.2.1 Instruction address       31         4.2.2 Operand address       33         CHAPTER 5 INSTRUCTION       35         5.1 Instruction Format       35         5.2 Outline of Instructions       39         5.3 Instruction Set       43         ADD       45         ADDI       46         AND       47         ANDI       48         Bcond       49         BSH       51         BSW       52         CALLT       53         CLR1       54                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      | 3.2.3  | Bit                                                        |    |
| 4.1       Memory Map                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 3.3  | Data / | Alignment                                                  | 28 |
| 4.1       Memory Map                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |      |        |                                                            |    |
| 4.2       Addressing Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | CHAP | TER 4  | ADDRESS SPACE                                              | 29 |
| 4.2       Addressing Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 41   | Memo   | ory Map                                                    | 30 |
| 4.2.1       Instruction address       31         4.2.2       Operand address       33         CHAPTER 5       INSTRUCTION       35         5.1       Instruction Format       35         5.2       Outline of Instructions       39         5.3       Instruction Set       43         ADD       45         ADD       45         ADD       46         AND       47         AND       47         Bcond       49         BSH       51         BSW       52         CALLT       53         CLR1       54                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |      |        |                                                            |    |
| 4.2.2       Operand address.       33         CHAPTER 5       INSTRUCTION.       35         5.1       Instruction Format.       35         5.2       Outline of Instructions       39         5.3       Instruction Set.       43         ADD       45         ADD       45         ADD       46         AND       47         AND       47         BSH       51         BSW       52         CALLT       53         CLR1       54                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |      |        | •                                                          |    |
| CHAPTER 5 INSTRUCTION       35         5.1 Instruction Format       35         5.2 Outline of Instructions       39         5.3 Instruction Set       43         ADD       45         ADD       46         AND       47         AND       47         Bcond       49         BSH       51         BSW       52         CALLT       53         CLR1       54                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |      |        |                                                            |    |
| 5.1       Instruction Format       35         5.2       Outline of Instructions       39         5.3       Instruction Set.       43         ADD.       45         ADDI       46         AND       47         ANDI       48         Bcond       49         BSH       51         BSW       52         CALLT       53         CLR1       54                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |        |                                                            |    |
| 5.2       Outline of Instructions       39         5.3       Instruction Set                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | CHAP | TER 5  | INSTRUCTION                                                | 35 |
| 5.2       Outline of Instructions       39         5.3       Instruction Set                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 51   | Inctru | intion Format                                              | 25 |
| 5.3       Instruction Set                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | -    |        |                                                            |    |
| ADD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | -    |        |                                                            |    |
| ADDI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0.0  |        |                                                            |    |
| AND                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |        |                                                            |    |
| ANDI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |      |        |                                                            | -  |
| Bcond                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |      |        |                                                            |    |
| BSH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |        |                                                            |    |
| BSW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |        |                                                            |    |
| CALLT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |      | -      |                                                            | _  |
| CLR1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |      | -      |                                                            | _  |
| CMOV                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |      |        |                                                            |    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |      | CMOV   | /                                                          | 55 |

| CMP     | 56  |
|---------|-----|
| CTRET   | 57  |
| DBRET   | 58  |
| DBTRAP  | 59  |
| DI      | 60  |
| DISPOSE | 61  |
| DIV     | 63  |
| DIVH    | 64  |
| DIVHU   | 66  |
| DIVU    | 67  |
| EI      | 68  |
| HALT    | 69  |
| HSW     | 70  |
| JARL    |     |
|         |     |
| JR      |     |
| LD.B    |     |
| LD.BU   |     |
| LD.H    |     |
| LD.HU   |     |
| LD.W    |     |
| LDSR    |     |
| MOV     | -   |
| -       |     |
| MOVEA   |     |
| MOVHI   | -   |
| MUL     |     |
| MULH    |     |
| MULHI   |     |
| MULU    |     |
| NOP     |     |
| NOT     | 88  |
| NOT1    | 89  |
| OR      |     |
| ORI     | 91  |
| PREPARE | 92  |
| RETI    | 94  |
| SAR     | 96  |
| SASF    | 97  |
| SATADD  | 98  |
| SATSUB  | 99  |
| SATSUBI | 100 |
| SATSUBR | 101 |
| SET1    | 102 |
| SETF    | 103 |
| SHL     | 105 |
| SHR     | 106 |
| SLD.B   | 107 |
| SLD.BU  |     |
|         |     |

|      | SLD.H   |                                                 |     |
|------|---------|-------------------------------------------------|-----|
|      | SLD.HU  |                                                 | 110 |
|      | SLD.W   |                                                 | 111 |
|      | SST.B   |                                                 | 112 |
|      | SST.H   |                                                 | 113 |
|      | SST.W   |                                                 | 114 |
|      | ST.B    |                                                 | 115 |
|      | ST.H    |                                                 | 116 |
|      | ST.W    |                                                 | 117 |
|      | STSR    |                                                 | 118 |
|      | SUB     |                                                 | 119 |
|      | SUBR    |                                                 | 120 |
|      |         | 1                                               |     |
|      | SXB     |                                                 | 122 |
|      |         |                                                 |     |
|      |         |                                                 |     |
|      |         |                                                 |     |
|      |         |                                                 |     |
|      |         |                                                 |     |
|      | -       |                                                 | -   |
|      |         |                                                 | -   |
| 5.4  |         | r of Instruction Execution Clock Cycles         |     |
|      |         |                                                 |     |
| 6.1  | -       | ot Servicing                                    |     |
|      |         | Maskable interrupt<br>Non-maskable interrupt    |     |
| 6.2  |         | ion Processing                                  |     |
| 0.2  | •       | Software exception                              |     |
|      |         | Exception trap                                  |     |
|      |         | Debug trap                                      |     |
| 6.3  |         | ing from Interrupt/Exception Processing         |     |
|      |         | Restoring from interrupt and software exception |     |
|      |         | Restoring from exception trap and debug trap    |     |
| CHAF | TER 7 F | RESET                                           | 144 |
| 7.1  | Registe | er Status After Reset                           | 144 |
| 7.2  | -       | g Up                                            |     |
| СНАР | TER 8 F | PIPELINE                                        |     |
| 8.1  |         | 95                                              |     |
| 0.1  |         | Non-blocking load/store                         |     |
|      |         | 2-clock branch                                  |     |
|      |         | Efficient pipeline processing                   |     |
| 8.2  |         | e Flow During Execution of Instructions         |     |
|      | •       | Load instructions                               |     |
|      |         |                                                 |     |

|   |      | 8.2.2   | Store instructions                                                 | 151 |
|---|------|---------|--------------------------------------------------------------------|-----|
|   |      | 8.2.3   | Multiply instructions                                              | 151 |
|   |      | 8.2.4   | Arithmetic operation instructions                                  | 153 |
|   |      | 8.2.5   | Saturated operation instructions                                   | 154 |
|   |      | 8.2.6   | Logical operation instructions                                     | 154 |
|   |      | 8.2.7   | Branch instructions                                                | 154 |
|   |      | 8.2.8   | Bit manipulation instructions                                      | 156 |
|   |      | 8.2.9   | Special instructions                                               | 156 |
|   |      | 8.2.10  | Debug function instructions                                        | 161 |
|   | 8.3  | Pipelin | e Disorder                                                         | 162 |
|   |      | 8.3.1   | Alignment hazard                                                   | 162 |
|   |      | 8.3.2   | Referencing execution result of load instruction                   | 163 |
|   |      | 8.3.3   | Referencing execution result of multiply instruction               | 164 |
|   |      | 8.3.4   | Referencing execution result of LDSR instruction for EIPC and FEPC | 165 |
|   |      | 8.3.5   | Cautions when creating programs                                    | 165 |
|   | 8.4  | Additio | onal Items Related to Pipeline                                     | 166 |
|   |      | 8.4.1   | Harvard architecture                                               | 166 |
|   |      | 8.4.2   | Short path                                                         | 167 |
|   | APPE | NDIX A  | INSTRUCTION LIST                                                   | 169 |
|   | APPE | NDIX B  | INSTRUCTION OPCODE MAP                                             | 183 |
|   | APPE | NDIX C  | DIFFERENCES IN ARCHITECTURE OF V850 CPU AND V850E1 CPU             | 188 |
|   | APPE | NDIX D  | INSTRUCTIONS ADDED FOR V850ES CPU COMPARED WITH V850 CPU           | 191 |
|   | APPE | NDIX E  | INDEX                                                              | 193 |
| * | APPE | NDIX F  | REVISION HISTORY                                                   | 196 |

# LIST OF FIGURES

| Figure No. Title |                                                                        | Page         |
|------------------|------------------------------------------------------------------------|--------------|
| 1-1              | V850 Series CPU Development                                            | 16           |
| 1-2              | Internal Block Diagram of V850ES CPU                                   |              |
|                  |                                                                        |              |
| 2-1              | Registers                                                              |              |
| 2-2              | Program Counter (PC)                                                   |              |
| 2-3              | Interrupt Status Saving Registers (EIPC, EIPSW)                        | 21           |
| 2-4              | NMI Status Saving Registers (FEPC, FEPSW)                              |              |
| 2-5              | Exception Cause Register (ECR)                                         |              |
| 2-6              | Program Status Word (PSW)                                              | 23           |
| 2-7              | CALLT Caller Status Saving Registers (CTPC, CTPSW)                     | 24           |
| 2-8              | Exception/Debug Trap Status Saving Registers (DBPC, DBPSW)             | 25           |
| 2-9              | CALLT Base Pointer (CTBP)                                              |              |
| 4-1              | Memory Map                                                             |              |
| 4-2              | Relative Addressing                                                    |              |
| 4-3              | Register Addressing (JMP [reg1] Instruction)                           |              |
| 4-4              | Based Addressing (Type 1)                                              |              |
| 4-5              | Based Addressing (Type 2)                                              |              |
| 4-6              | Bit Addressing                                                         |              |
| 6-1              | Maskable Interrupt Servicing Format                                    | 137          |
| 6-2              | Non-Maskable Interrupt Servicing Format                                |              |
| 6-3              | Software Exception Processing Format                                   |              |
| 6-4              | Illegal Instruction Code                                               |              |
| 6-5              | Exception Trap Processing Format                                       |              |
| 6-6              | Debug Trap Processing Format                                           |              |
| 6-7              | Restoration from Interrupt/Software Exception Processing Format        |              |
| 6-8              | Restoration from Exception Trap/Debug Trap Processing Format           |              |
|                  |                                                                        |              |
| 8-1              | Example of Executing Nine Standard Instructions                        |              |
| 8-2              | Pipeline Configuration                                                 |              |
| 8-3              | Non-Blocking Load/Store                                                | 147          |
| 8-4              | Pipeline Operations with Branch Instructions                           | 148          |
| 8-5              | Parallel Execution of Branch Instructions                              | 149          |
| 8-6              | Align Hazard Example                                                   |              |
| 8-7              | Example of Execution Result of Load Instruction                        |              |
| 8-8              | Example of Execution Result of Multiply Instruction                    |              |
| 8-9              | Example of Referencing Execution Result of LDSR Instruction for EIPC a | and FEPC 165 |

# LIST OF TABLES

| Table | Table No. Title                                      |                                        | Page |
|-------|------------------------------------------------------|----------------------------------------|------|
| 2-1   | Program Registers                                    |                                        | 19   |
| 2-2   | System Register Numbers                              |                                        | 20   |
| 5-1   | Conventions of Instruction Format                    |                                        | 43   |
| 5-2   | Conventions of Operation                             |                                        | 43   |
| 5-3   | Conventions of Opcode                                |                                        | 44   |
| 5-4   | Bcond Instructions                                   |                                        | 50   |
| 5-5   | Condition Codes                                      |                                        | 104  |
| 5-6   | List of Number of Instruction Execution Clock Cycles |                                        | 131  |
| 6-1   | Interrupt/Exception Codes                            |                                        |      |
| 7-1   | Register Status After Reset                          |                                        | 144  |
| A-1   | Instruction Function List (in Alphabetical Order)    |                                        |      |
| A-2   | Instruction List (in Format Order)                   |                                        |      |
| D-1   | Instructions Added to V850ES CPU and V850 CPU        | nstructions with Same Instruction Code |      |

#### **CHAPTER 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 conventionally employ 8-bit or 16-bit microcontrollers. 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 Series<sup>™</sup> 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 of CISC single-chip microcontrollers at a lower total cost.

In addition to the basic instructions of conventional RISC CPUs, the V850 Series 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.

Furthermore, to improve the performance of the V850 Series, new CPU cores, the V850E1 and V850E2 (under development), are being introduced. These CPU cores are based on the conventional V850 CPU and maintain upward instruction compatibility, but feature enhanced operating frequencies and pipeline efficiency.

Another new CPU core, the V850ES, was developed for use in applications that primarily employ 16-bit microcontrollers, and offers the kind of high performance at a low cost demanded in this field.

The V850ES is a high-performance, compact CPU core that provides a set of functions (operating frequency, multiplier, DMA) optimized for the 16-bit microcontroller market, while maintaining compatibility with the V850E1 CPU with a proven record in 50 MHz class products.



Figure 1-1. V850 Series CPU Development

#### 1.1 Features

\*

#### (1) High-performance 32-bit architecture for embedded control

- Number of instructions: 83
- 32-bit general-purpose 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: 64 MB linear (Usable area: 16 MB linear space + internal RAM area 60 KB)
   Data space: 4 GB linear

#### (2) Special instructions

- Saturation operation instructions
- Bit manipulation instructions
- Multiply instructions (On-chip hardware multiplier executing multiplication in 1 or 4 clocks) 16 bits × 16 bits → 32 bits
  - 32 bits  $\times$  32 bits  $\rightarrow$  32 bits or 64 bits

# **1.2 Internal Configuration**

The V850ES 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.

It 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.

Figure 1-2 shows the internal block diagram.



Figure 1-2. Internal Block Diagram of V850ES CPU

# CHAPTER 2 REGISTER SET

The registers can be classified into two types: program registers that can be used for general programming, and system registers that can control the execution environment. All the registers are 32 bits wide.

| (a) Program registers            | (b) System registers                                |
|----------------------------------|-----------------------------------------------------|
| r0 (Zero register)               | EIPC (Interrupt status saving register)             |
| r1 (Assembler-reserved register) | EIPSW (Interrupt status saving register)            |
| r2                               |                                                     |
| r3 (Stack pointer (SP))          | FEPC (NMI status saving register)                   |
| r4 (Global pointer (GP))         | FEPSW (NMI status saving register)                  |
| r5 (Text pointer (TP))           | ECR (Exception cause register)                      |
| r6                               |                                                     |
| r7                               | PSW (Program status word)                           |
| r8                               |                                                     |
| r9                               | CTPC (CALLT caller status saving register)          |
| r10                              | CTPSW (CALLT caller status saving register)         |
| r11                              | DBPC (Exception/debug trap status saving register)  |
| r12                              | DBPSW (Exception/debug trap status saving register) |
| r13                              |                                                     |
| r14                              | CTBP (CALLT base pointer)                           |
| 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-1. Registers

# 2.1 Program Registers

There are general-purpose registers (r0 to r31) and program counter (PC) in the program registers.

| Program Register | Name      | Function                                            | Description                                                                                  |  |  |
|------------------|-----------|-----------------------------------------------------|----------------------------------------------------------------------------------------------|--|--|
| General-purpose  | rO        | Zero register                                       | Always holds 0.                                                                              |  |  |
| register         | r1        | Assembler-reserved register                         | Used as working register for address generation.                                             |  |  |
|                  | r2        | Address/data variable register                      | Address/data variable register (when the real-time OS to be used is not using r2)            |  |  |
|                  | r3        | Stack pointer (SP)                                  | Used for stack frame generation when function is called.                                     |  |  |
|                  | r4        | Global pointer (GP)                                 | Used to access global variable in data area.                                                 |  |  |
|                  | r5        | Text pointer (TP)                                   | Used as register for pointing start address of text area (area where program code is placed) |  |  |
|                  | r6 to r29 | Address/data variable registers                     | 5                                                                                            |  |  |
|                  | r30       | Element pointer (EP)                                | Used as base pointer for address generation when memory is accessed.                         |  |  |
|                  | r31       | Link pointer (LP)                                   | Used when compiler calls function.                                                           |  |  |
| Program counter  | PC        | Holds instruction address during program execution. |                                                                                              |  |  |

| Table 2 | 2-1. | Program | Registers |
|---------|------|---------|-----------|
|---------|------|---------|-----------|

Remark For detailed descriptions of r1, r3 to r5, and r31 used by assembler and C compiler, refer to the CA850 (C Compiler Package) Assembly Language User's Manual.

#### (1) General-purpose registers (r0 to r31)

Thirty-two general-purpose registers, r0 to r31, are provided. All these registers can be used for data variable or address variable. 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, r3 to 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. r2 is sometimes used by the real-time OS. When the real-time OS to be used is not using r2, r2 can be used as a variable register.

#### (2) Program counter (PC)

This register holds an instruction address during program execution. The lower 26 bits of this register are valid, and bits 31 to 26 are reserved for future function expansion (fixed to 0). If a carry occurs from bit 25 to bit 26, it is ignored. Bit 0 is always fixed to 0, and execution cannot branch to an odd address.



#### Figure 2-2. Program Counter (PC)

# 2.2 System Registers

The system registers control the status and holds information on interrupts.

System registers can be read or written by specifying the relevant system register number from the following list using the LDSR and STSR instructions.

| Register | Register Name                                                                                 | Operand S           | Operand Specifiability |  |
|----------|-----------------------------------------------------------------------------------------------|---------------------|------------------------|--|
| No.      |                                                                                               | LDSR<br>Instruction | STSR<br>Instruction    |  |
| 0        | Interrupt status saving register (EIPC)                                                       | 0                   | 0                      |  |
| 1        | Interrupt status saving register (EIPSW)                                                      | 0                   | 0                      |  |
| 2        | NMI status saving register (FEPC)                                                             | 0                   | 0                      |  |
| 3        | NMI status saving register (FEPSW)                                                            | 0                   | 0                      |  |
| 4        | Exception cause register (ECR)                                                                | ×                   | 0                      |  |
| 5        | Program status word (PSW)                                                                     | 0                   | 0                      |  |
| 6 to 15  | (Numbers reserved for future function expansion (operation cannot be guaranteed if accessed)) | ×                   | ×                      |  |
| 16       | CALLT caller status saving register (CTPC)                                                    | 0                   | 0                      |  |
| 17       | CALLT caller status saving register (CTPSW)                                                   | 0                   | 0                      |  |
| 18       | Exception/debug trap status saving register (DBPC)                                            | 0                   | 0                      |  |
| 19       | Exception/debug trap status saving register (DBPSW)                                           | 0                   | 0                      |  |
| 20       | CALLT base pointer (CTBP)                                                                     | 0                   | 0                      |  |
| 21 to 31 | (Numbers reserved for future function expansion (operation cannot be guaranteed if accessed)) | ×                   | ×                      |  |

| Table 2-2. | System | Register | Numbers |
|------------|--------|----------|---------|
|------------|--------|----------|---------|

Caution When returning from interrupt servicing using the RETI instruction after setting bit 0 of EIPC, FEPC, or CTPC to 1 using the LDSR instruction, the value of bit 0 is ignored (because bit 0 of the PC is fixed to 0). Therefore, be sure to set an even number (bit 0 = 0) when setting a value in EIPC, FEPC, or CTPC.

Remark O: Accessible

×: Inaccessible

#### 2.2.1 Interrupt status saving registers (EIPC, EIPSW)

Two interrupt status saving registers are provided: EIPC and EIPSW.

If a software exception or maskable interrupt occurs, the contents of the program counter (PC) are saved to EIPC, and the contents of the program status word (PSW) are saved to EIPSW (if a non-maskable interrupt (NMI) occurs, the contents are saved to NMI status saving registers (FEPC, FEPSW)).

Except for part of instructions, the address of the instruction next to the one executed when the software exception or maskable interrupt has occurred is saved to the EIPC (see **Table 6-1 Interrupt/Exception Codes**).

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 31 to 26 of the EIPC and bits 31 to 8 of the EIPSW are reserved for future function expansion (fixed to 0).



#### Figure 2-3. Interrupt Status Saving Registers (EIPC, EIPSW)

#### 2.2.2 NMI status saving registers (FEPC, FEPSW)

Two NMI status saving registers are provided: FEPC and FEPSW.

If a non-maskable interrupt (NMI) occurs, the contents of the program counter (PC) are saved to FEPC, and the contents of the program status word (PSW) are saved to FEPSW.

Except for part of instructions, the address of the instruction next to the one executed when the NMI has occurred is saved to the FEPC (see **Table 6-1 Interrupt/Exception Codes**).

The current value of the PSW is saved to the FEPSW.

Because only one pair of NMI status saving registers is provided, the contents of these registers must be saved by program when multiple interrupts are enabled.

Bits 31 to 26 of the FEPC and bits 31 to 8 of the FEPSW are reserved for future function expansion (fixed to 0).



#### Figure 2-4. NMI Status Saving Registers (FEPC, FEPSW)

#### 2.2.3 Exception cause register (ECR)

The exception cause register (ECR) holds the cause information when an exception or interrupt occurs. The ECR holds an exception code which identifies each interrupt source (see **Table 6-1 Interrupt/Exception Codes**). This is a read-only register, and therefore, no data can be written to it by using the LDSR instruction.





#### 2.2.4 Program status word (PSW)

The program status word (PSW) 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 bits in this 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, interrupt requests are already disabled even while the LDSR instruction is executing.

Bits 31 to 8 are reserved for future function expansion (fixed to 0).



| sw o o     | 0 0 0 0 0           | 0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0 |  |  |  |
|------------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bit Positi | on Flag Name        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
| 7          | NP                  | Indicates that non-maskable interrupt (NMI) processing is in progress. This flag is set to 1<br>when NMI request is acknowledged, and multiple interrupts are disabled.<br>0: NMI processing is not in progress<br>1: NMI processing is in progress                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
| 6          | EP                  | <ul> <li>Indicates that exception processing is in progress. This flag is set to 1 when an exception occurs. Even when this bit is set, interrupt requests can be acknowledged.</li> <li>0: Exception processing is not in progress</li> <li>1: Exception processing is in progress</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
| 5          | ID                  | Indicates whether maskable interrupt request can be acknowledged.<br>0: Interrupt can be acknowledged<br>1: Interrupt cannot be acknowledged                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
| 4          | SAT <sup>Note</sup> | Indicates that an overflow has occurred in a saturate operation and the result is saturated.<br>This is a cumulative flag. When the result is saturated, the flag is set to 1 and is not cleared to 0 even if the next result does not saturate. To clear this flag to 0, use the LDSR instruction. This flag is neither set to 1 nor cleared to 0 by execution of arithmetic operation instruction.<br>0: Not saturated<br>1: Saturated                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
| 3          | СҮ                  | <ul><li>Indicates whether carry or borrow occurred as a result of the operation.</li><li>0: Carry or borrow did not occur</li><li>1: Carry or borrow occurred</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |
| 2          | OV <sup>Note</sup>  | Indicates whether overflow occurred as a result of the operation.<br>0: Overflow did not occur<br>1: Overflow occurred                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
| 1          | S <sup>Note</sup>   | Indicates whether the result of the operation is negative.<br>0: Result is positive or zero<br>1: Result is negative                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |

| Figure 2-6. | Program Sta | tus Word (PSW) (2/2) |
|-------------|-------------|----------------------|
|-------------|-------------|----------------------|

| Bit Position | Flag Name | Function                                                                                                                                                                         |
|--------------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0            | Z         | Indicates whether the result of the operation is zero.<br>0: Result is not zero<br>1: Result is zero                                                                             |
|              |           | saturate instructions, the SAT, S, and OV flags will be set according to the result of<br>the shown in the table below. Note that the SAT flag is set to 1 only when the OV flag |

| Status of Operation                    | Status of Flag         |    |   | Operation Result of Saturation |
|----------------------------------------|------------------------|----|---|--------------------------------|
| Result                                 | SAT                    | OV | S | Processing                     |
| Maximum positive<br>value is exceeded  | 1                      | 1  | 0 | 7FFFFFFH                       |
| Maximum negative value is exceeded     | 1                      | 1  | 1 | 8000000H                       |
| Positive (Not exceeding maximum value) | Holds the value before | 0  | 0 | Operation result               |
| Negative (Not exceeding maximum value) | operation              |    | 1 |                                |

# 2.2.5 CALLT caller status saving registers (CTPC, CTPSW)

Two CALLT caller status saving registers are provided: CTPC and CTPSW.

If a CALLT instruction is executed, the contents of the program counter (PC) are saved to CTPC, and the contents of the program status word (PSW) are saved to CTPSW.

The contents saved to the CTPC are the address of the instruction next to the CALLT instruction.

The current value of the PSW is saved to the CTPSW.

Bits 31 to 26 of the CTPC and bits 31 to 8 of the CTPSW are reserved for future function expansion (fixed to 0).

Figure 2-7. CALLT Caller Status Saving Registers (CTPC, CTPSW)



#### 2.2.6 Exception/debug trap status saving registers (DBPC, DBPSW)

Two exception/debug trap status saving registers are provided: DBPC and DBPSW.

If an exception trap or debug trap occurs, the contents of the program counter (PC) are saved to DBPC, and the contents of the program status word (PSW) are saved to DBPSW.

The contents saved to the DBPC are the address of the instruction next to the one executed when the exception trap or debug trap has occurred.

The current value of the PSW is saved to the DBPSW.

Bits 31 to 26 of the DBPC and bits 31 to 8 of the DBPSW are reserved for future function expansion (fixed to 0).

#### Figure 2-8. Exception/Debug Trap Status Saving Registers (DBPC, DBPSW)



#### 2.2.7 CALLT base pointer (CTBP)

The CALLT base pointer (CTBP) is used to specify a table address and to generate a target address (bit 0 is fixed to 0).

Bits 31 to 26 are reserved for future function expansion (fixed to 0).

#### Figure 2-9. CALLT Base Pointer (CTBP)



# CHAPTER 3 DATA TYPE

# 3.1 Data Format

The following data types are supported (see 3.2 Data Representation).

- Integer (32, 16, 8 bits)
- Unsigned integer (32, 16, 8 bits)
- Bit

Three types of data lengths: word (32 bits), halfword (16 bits), and byte (8 bits) are supported. 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) 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 (Least Significant Bit) is bit 0 and the MSB (Most Significant Bit) is bit 31. A word is specified by its address A (with the 2 lowest bits fixed to 0 when misalign access is disabled<sup>Note</sup>), and occupies 4 bytes, A, A+1, A+2, and A+3.

**Note** When misalign access is enabled, any byte boundary can be accessed whether access is in halfword or word units. See **3.3 Data Alignment**.



#### (2) Halfword

A halfword is 2-byte (16-bit) contiguous data that starts from any halfword 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 halfword is specified by its address A (with the lowest bit fixed to 0<sup>Note</sup>), and occupies 2 bytes, A and A+1.

**Note** When misalign access is enabled, any byte boundary can be accessed whether access is in halfword or word units. See **3.3 Data Alignment**.



#### (3) 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 is bit 0 and the MSB is bit 7. A byte is specified by its address A.

**Note** When misalign access is enabled, any byte boundary can be accessed whether access is in halfword or word units. See **3.3 Data Alignment**.



# (4) 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** When misalign access is enabled, any byte boundary can be accessed whether access is in halfword or word units. See **3.3 Data Alignment**.



#### 3.2 Data Representation

#### 3.2.1 Integer

An integer is expressed as a binary number of 2's complement and is 32, 16, or 8 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.

The integer range of each data length is as follows.

- Word (32 bits): -2,147,483,648 to +2,147,483,647
- Halfword (16 bits): -32,768 to +32,767
- Byte (8 bits): -128 to +127

#### 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 32, 16, or 8 bits long. Regardless of its length, 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.

The unsigned integer range of each data length is as follows.

- Word (32 bits): 0 to 4,294,967,295
- Halfword (16 bits): 0 to 65,535
- Byte (8 bits): 0 to 255

#### 3.2.3 Bit

1-bit data that can take a value of 0 (cleared) or 1 (set) can be handled as a bit data. Bit manipulation can be performed only to 1-byte data in the memory space in the following four ways:

- SET1
- CLR1
- NOT1
- TST1

#### 3.3 Data Alignment

Due to the incorporation of a misalign function, data that is allocated to the memory can be placed at any address regardless of the data format (word data, halfword data). However, if word data is not aligned at a word boundary (the lower 2 bits of the address are 0), or halfword data is not aligned at a halfword boundary (the lowest bit of the address is 0), one or more surplus bus cycles are generated, which lowers the bus efficiency.

#### **CHAPTER 4 ADDRESS SPACE**

The V850ES CPU supports a 4 GB linear address space. Both memory and I/O are mapped to this address space (memory-mapped I/O). The V850ES CPU outputs 32-bit addresses to the memory and I/O. The maximum address is 2<sup>32</sup>–1.

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 (little endian).

Data consisting of 2 bytes is called a halfword, and 4-byte data is called a word.

In this User's Manual, data consisting of 2 or more bytes is illustrated as shown below, with the lower address shown on the right and the higher address on the left.



# 4.1 Memory Map

The V850ES CPU employs a 32-bit architecture and supports a linear address space (data area) of up to 4 GB for operand addressing (data access).

It supports a linear address space (program area) of up to 64 MB for instruction addressing. However, areas usable as program area are a linear address space of up to 16 MB and the internal RAM area (60 KB max.).

Figure 4-1 shows the 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 addressing (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 (S).

This addressing is used for JARL disp22, reg2, JR disp22, and Bcond disp9 instructions.





Figure 4-2. Relative Addressing (2/2)



# (2) Register addressing (register indirect)

The contents of a general-purpose register (reg1) specified by an instruction are transferred to the program counter (PC).

This addressing is applied to the JMP [reg1] instruction.





#### 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-purpose register or system register specified in the general-purpose register specification field is accessed as operand.

This addressing mode applies to instructions using the operand format reg1, reg2, reg3, or regID.

#### (2) Immediate addressing

The 5-bit or 16-bit data for manipulation is contained in the instruction code. 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 to 1FH), and is used in TRAP instruction.
  - cccc: Operand consisting of 4-bit data used in CMOV, SASF, and SETF instructions 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-purpose register (reg1) to the 16-bit displacement value (disp16) contained in the instruction code. This addressing mode applies to instructions using the operand format disp16 [reg1].





# (b) Type 2

The address of the data memory location to be accessed is determined by adding the value in the element pointer (r30) to the 7- or 8-bit displacement value (disp7, disp8). This addressing mode applies to SLD and SST instructions.



#### Figure 4-5. Based Addressing (Type 2)

#### (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-purpose register (reg1) and a 16-bit displacement (disp16) sign-extended to a word length.

This addressing mode applies only to bit manipulate instructions.



# Figure 4-6. Bit Addressing

# **CHAPTER 5 INSTRUCTION**

# 5.1 Instruction Format

There are two types of instruction formats: 16-bit and 32-bit. The 16-bit format instructions include binary operation, control, and conditional branch instructions, and the 32-bit format instructions include load/store, jump, and instructions that handle 16-bit immediate data.

An instruction is actually stored in memory as follows:

- Lower bytes of instruction (including bit 0)  $\rightarrow$  lower address
- Higher bytes of instruction (including bit 15 or bit 31)  $\rightarrow$  higher address

Caution Some instructions have an unused field (RFU). This field is reserved for future expansion and must be fixed to 0.

# (1) reg-reg instruction (Format I)

A 16-bit instruction format having a 6-bit opcode field and two general-purpose register specification fields.



#### (2) imm-reg instruction (Format II)

A 16-bit instruction format having a 6-bit opcode field, 5-bit immediate field, and a general-purpose register specification field.



# (3) Conditional branch instruction (Format III)

A 16-bit instruction format having a 4-bit opcode field, 4-bit condition code field, and an 8-bit displacement field.



# (4) 16-bit load/store instruction (Format IV)

A 16-bit instruction format having a 4-bit opcode field, a general-purpose register specification field, and a 7-bit displacement field (or 6-bit displacement field + 1-bit sub-opcode field).



A 16-bit instruction format having a 7-bit opcode field, a general-purpose register specification field, and a 4-bit displacement field.



#### (5) Jump instruction (Format V)

A 32-bit instruction format having a 5-bit opcode field, a general-purpose register specification field, and a 22-bit displacement field.



### (6) 3-operand instruction (Format VI)

A 32-bit instruction format having a 6-bit opcode field, two general-purpose register specification fields, and a 16bit immediate field.



### (7) 32-bit load/store instruction (Format VII)

A 32-bit instruction format having a 6-bit opcode field, two general-purpose register specification fields, and a 16bit displacement field (or 15-bit displacement field + 1-bit sub-opcode field).



### (8) Bit manipulation instruction (Format VIII)

A 32-bit instruction format having a 6-bit opcode field, 2-bit sub-opcode field, 3-bit bit specification field, a general-purpose register specification field, and a 16-bit displacement field.



### (9) Extended instruction format 1 (Format IX)

A 32-bit instruction format having a 6-bit opcode field, 6-bit sub-opcode field, and two general-purpose register specification fields (one field may be register number field (regID) or condition code field (cond)).



### (10) Extended instruction format 2 (Format X)

A 32-bit instruction format having a 6-bit opcode field and 6-bit sub-opcode field.



### (11) Extended instruction format 3 (Format XI)

A 32-bit instruction format having a 6-bit opcode field, 6-bit and 1-bit sub-opcode field, and three generalpurpose register specification fields.



### (12) Extended instruction format 4 (Format XII)

A 32-bit instruction format having a 6-bit opcode field, 4-bit and 1-bit sub-opcode field, 10-bit immediate field, and two general-purpose register specification fields.



### (13) Stack manipulation instruction 1 (Format XIII)

A 32-bit instruction format having a 5-bit opcode field, 5-bit immediate field, 12-bit register list field, and one general-purpose register specification field (or 5-bit sub-opcode field).



### 5.2 Outline of Instructions

### (1) Load instructions

Transfer data from memory to a register. The following instructions (mnemonics) are provided.

### (a) LD instructions

- LD.B: Load byte
- LD.BU: Load byte unsigned
- LD.H: Load halfword
- LD.HU: Load halfword unsigned
- LD.W: Load word

### (b) SLD instructions

- SLD.B: Short format load byte
- SLD.BU: Short format load byte unsigned
- SLD.H: Short format load halfword
- SLD.HU: Short format load halfword unsigned
- SLD.W: Short format load word

### (2) Store instructions

Transfer data from register to a memory. The following instructions (mnemonics) are provided.

### (a) ST instructions

- ST.B: Store byte
- ST.H: Store halfword
- ST.W: Store word

### (b) SST instructions

- SST.B: Short format store byte
- SST.H: Short format store halfword
- SST.W: Short format store word

### (3) Multiply instructions

Execute multiply processing in 1 to 5 clocks with on-chip hardware multiplier. The following instructions (mnemonics) are provided.

- MUL: Multiply word
- MULH: Multiply halfword
- MULHI: Multiply halfword immediate
- MULU: Multiply word unsigned

Add, subtract, divide, transfer, or compare data between registers. The following instructions (mnemonics) are provided.

- ADD: Add
- ADDI: Add immediate
- CMOV: Conditional move
- CMP: Compare
- DIV: Divide word
- DIVH: Divide halfword
- DIVHU: Divide halfword unsigned
- DIVU: Divide word unsigned
- MOV: Move
- MOVEA: Move effective address
- MOVHI: Move high halfword
- SASF: Shift and set flag condition
- SETF: Set flag condition
- SUB: Subtract
- SUBR: Subtract reverse

### (5) Saturated operation instructions

Execute saturation addition and subtraction. If the result of the operation exceeds the maximum positive value (7FFFFFFH), 7FFFFFFH is returned. If the result of the operation exceeds the maximum negative value (80000000H), 8000000H is returned. The following instructions (mnemonics) are provided.

- SATADD: Saturated add
- SATSUB: Saturated subtract
- SATSUBI: Saturated subtract immediate
- SATSUBR: Saturated subtract reverse

### (6) Logical operation instructions

These instructions include logical operation 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 on-chip barrel shifter. The following instructions (mnemonics) are provided.

- AND: AND
- ANDI: AND immediate
- BSH: Byte swap halfword
- BSW: Byte swap word
- HSW: Halfword swap word
- NOT: NOT
- OR: OR
- ORI: OR immediate
- SAR: Shift arithmetic right
- SHL: Shift logical left
- SHR: Shift logical right
- SXB: Sign extend byte
- SXH: Sign extend halfword

- TST: Test
- XOR: Exclusive OR
- XORI: Exclusive OR immediate
- ZXB: Zero extend byte
- ZXH: Zero extend halfword

### (7) Branch instructions

These instructions include unconditional branch instructions (JARL, JMP, JR) and conditional branch instruction (Bcond) which alters the control depending on the status of flags. Program control can be transferred to the address specified by a branch instruction. The following instructions (mnemonics) are provided.

- Bcond (BC, BE, BGE, BGT, BH, BL, BLE, BLT, BN, BNC, BNE, BNH, BNL, BNV, BNZ, BP, BR, BSA, BV, BZ):
   Branch on condition code
- JARL: Jump and register link
- JMP: Jump register
- JR: Jump relative

### (8) Bit manipulation instructions

Execute a logical operation to the specified bit data in memory. The following instructions (mnemonics) are provided.

- CLR1: Clear bit
- NOT1: Not bit
- SET1: Set bit
- TST1: Test bit

### (9) Special instructions

These instructions are instructions not included in the categories of instructions described above. The following instructions (mnemonics) are provided.

- CALLT: Call with table look up
- CTRET: Return from CALLT
- DI: Disable interrupt
- DISPOSE: Function dispose
- El: Enable interrupt
- HALT: Halt
- LDSR: Load system register
- NOP: No operation
- PREPARE: Function prepare
- RETI: Return from trap or interrupt
- STSR: Store system register
- SWITCH: Jump with table look up
- TRAP: Trap

### (10) Debug function instructions

These instructions are instructions reserved for debug function. The following instructions (mnemonics) are provided.

- DBRET: Return from debug trap
- DBTRAP: Debug trap

### 5.3 Instruction Set

In this section, mnemonic of each instruction is described divided into the following items.

- Instruction format: Indicates the description and operand of the instruction (for symbols, see Table 5-1).
- Operation: Indicates the function of the instruction (for symbols, see Table 5-2).
- Format: Indicates the instruction format (see 5.1 Instruction Format).
- Opcode: Indicates the bit field of the instruction opcode (for symbols, see **Table 5-3**).
- Flag: Indicates the operation of the flag which is altered after executing the instruction.
- 0 indicates clear (reset), 1 indicates set, and indicates no change.
- Explanation: Explains the operation of the instruction.
- Remark: Explains the supplementary information of the instruction.
- Caution: Indicates the cautions.

### Table 5-1. Conventions of Instruction Format

| Symbol | Meaning                                                                                                       |
|--------|---------------------------------------------------------------------------------------------------------------|
| reg1   | General-purpose register (used as source register)                                                            |
| reg2   | General-purpose register (mainly used as destination register. Some are also used as source registers)        |
| reg3   | General-purpose register (mainly used as remainder of division results or higher 32 bits of multiply results) |
| bit#3  | 3-bit data for specifying bit number                                                                          |
| imm×   | ×-bit immediate data                                                                                          |
| disp×  | ×-bit displacement data                                                                                       |
| regID  | System register number                                                                                        |
| vector | 5-bit data for trap vector (00H to1FH) specification                                                          |
| сссс   | 4-bit data for condition code specification                                                                   |
| sp     | Stack pointer (r3)                                                                                            |
| ер     | Element pointer (r30)                                                                                         |
| list×  | Lists of registers (x is a maximum number of registers)                                                       |

### Table 5-2. Conventions of Operation (1/2)

| Symbol                     | Meaning                              |  |  |
|----------------------------|--------------------------------------|--|--|
| <i>←</i>                   | Assignment                           |  |  |
| GR [ ]                     | General-purpose 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       |  |  |

| Table 5-2. | Conventions of Op | eration (2/2) |
|------------|-------------------|---------------|
|            | ••••••••          |               |

| Symbol                        | Meaning                                                                                                                                                                    |
|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| saturated (n)                 | Performs saturation processing of n.<br>If $n \ge 7FFFFFFH$ as result of calculation, $n = 7FFFFFFH$ .<br>If $n \le 80000000H$ as result of calculation, $n = 80000000H$ . |
| result                        | Reflects result on flag                                                                                                                                                    |
| Byte                          | Byte (8 bits)                                                                                                                                                              |
| Halfword                      | Halfword (16 bits)                                                                                                                                                         |
| Word                          | Word (32 bits)                                                                                                                                                             |
| +                             | Add                                                                                                                                                                        |
| -                             | Subtract                                                                                                                                                                   |
| П                             | Bit concatenation                                                                                                                                                          |
| ×                             | Multiply                                                                                                                                                                   |
| ÷                             | Divide                                                                                                                                                                     |
| %                             | Remainder of division results                                                                                                                                              |
| 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                                                                                                                                                     |

### Table 5-3. Conventions of Opcode

| Symbol | Meaning                                                          |
|--------|------------------------------------------------------------------|
| R      | 1-bit data of code specifying reg1 or regID                      |
| r      | 1-bit data of code specifying reg2                               |
| w      | 1-bit data of code specifying reg3                               |
| d      | 1-bit data of displacement                                       |
| 1      | 1-bit data of immediate (indicates higher bits of immediate)     |
| i      | 1-bit data of immediate                                          |
| сссс   | 4-bit data for condition code specification                      |
| CCCC   | 4-bit data for condition code specification of Bcond instruction |
| bbb    | 3-bit data for bit number specification                          |
| L      | 1-bit data of code specifying program register in register list  |

(1) Format I

(2) Format II

15

15

(1)

(2)

rrrrr001110RRRRR

rrrrr010010iiiii

Format

Opcode

| ADD                |                                                                                                                   | Add register/immediate |
|--------------------|-------------------------------------------------------------------------------------------------------------------|------------------------|
|                    |                                                                                                                   | Add                    |
| Instruction format | <ol> <li>(1) ADD reg1, reg2</li> <li>(2) ADD imm5, reg2</li> </ol>                                                |                        |
| Operation          | <ol> <li>(1) GR [reg2] ← GR [reg2] + GR [reg1]</li> <li>(2) GR [reg2] ← GR [reg2] + sign-extend (imm5)</li> </ol> |                        |

| Flag        | CY 1 if a carry occurs from MSB; otherwise, 0.                                                                                                                                                                                       |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | OV 1 if overflow occurs; otherwise, 0.                                                                                                                                                                                               |
|             | S 1 if the operation result is negative; otherwise, 0.                                                                                                                                                                               |
|             | Z 1 if the operation result is 0; otherwise 0.                                                                                                                                                                                       |
|             | SAT –                                                                                                                                                                                                                                |
| Explanation | (1) Adds the word data of general-purpose register reg1 to the word data of general-purpose<br>register reg2, and stores the result to general-purpose register reg2. The data of general-<br>purpose register reg1 is not affected. |
|             | (0) Adde E bit immediate data aign extended to word length to the word data of general                                                                                                                                               |

0

0

(2) Adds 5-bit immediate data, sign-extended to word length, to the word data of generalpurpose register reg2, and stores the result to general-purpose register reg2.

| ADDI               |                                                        | Add immediate |
|--------------------|--------------------------------------------------------|---------------|
|                    |                                                        | Add Immediate |
| Instruction format | ADDI imm16, reg1, reg2                                 |               |
| Operation          | $GR [reg2] \leftarrow GR [reg1] + sign-extend (imm16)$ |               |
| Format             | Format VI                                              |               |
| Opcode             | 15 0 31 16                                             |               |
|                    | rrrr110000RRRR iiiiiiiiiiiiiiiiiiiiiiiiiiiii           |               |
|                    |                                                        |               |

| Flag | CY  | 1 if a carry occurs from MSB; otherwise, 0.          |
|------|-----|------------------------------------------------------|
|      | OV  | 1 if overflow occurs; otherwise, 0.                  |
|      | S   | 1 if the operation result is negative; otherwise, 0. |
|      | Z   | 1 if the operation result is 0; otherwise 0.         |
|      | SAT | -                                                    |
|      |     |                                                      |

**Explanation** Adds 16-bit immediate data, sign-extended to word length, to the word data of generalpurpose register reg1, and stores the result to general-purpose register reg2. The data of general-purpose register reg1 is not affected.

# <Logical operation instruction>

| AND | AND     |
|-----|---------|
|     | <br>And |
|     |         |

| Instruction format | AND reg1, reg2                                                                                                                                                                        |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation          | $GR [reg2] \leftarrow GR [reg2] AND GR [reg1]$                                                                                                                                        |
| Format             | Format I                                                                                                                                                                              |
| Opcode             | 15 0<br>rrrr001010RRRR                                                                                                                                                                |
| Flag               | CY-OV0S1 if the MBS of the word data of the operation result is 1; otherwise, 0.Z1 if the operation result is 0; otherwise 0.SAT-                                                     |
| Explanation        | ANDs the word data of general-purpose register reg2 with the word data of general-purpose register reg1, and stores the result to general-purpose register reg2. The data of general- |

purpose register reg1 is not affected.

# <Logical operation instruction>

| ANDI               |                                                                                  | AND immediate    |
|--------------------|----------------------------------------------------------------------------------|------------------|
|                    |                                                                                  | And Immediate    |
|                    |                                                                                  | And immediate    |
| Instruction format | ANDI imm16, reg1, reg2                                                           |                  |
|                    |                                                                                  |                  |
| Operation          | $GR \text{ [reg2]} \leftarrow GR \text{ [reg1]} AND \text{ zero-extend (imm16)}$ |                  |
| <b>_</b> .         |                                                                                  |                  |
| Format             | Format VI                                                                        |                  |
| Opcode             | 15 0 31 16                                                                       |                  |
|                    | rrrr110110RRRRR iiiiiiiiiiiiiiiiiiii                                             |                  |
|                    |                                                                                  |                  |
| Flag               | CY –                                                                             |                  |
|                    | OV 0                                                                             |                  |
|                    | S 1 if the MSB of the word data of the operation result is 1; otherwise, 0.      |                  |
|                    | Z 1 if the operation result is 0; otherwise 0.                                   |                  |
|                    | SAT –                                                                            |                  |
| Explanation        | ANDs the word data of general-purpose register reg1 with the value of the        | 16-hit immediate |
|                    | data zero-extended to word length and stores the result to general-purpose       |                  |

 planation
 ANDs the word data of general-purpose register reg1 with the value of the 16-bit immediate data, zero-extended to word length, and stores the result to general-purpose register reg2. The data of general-purpose register reg1 is not affected.

### <Branch instruction>

|                    | Branch on condition code with 9-bit displacement                                                                                                                                                                                                                                                                |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bcond              |                                                                                                                                                                                                                                                                                                                 |
|                    | Branch on Condition Code                                                                                                                                                                                                                                                                                        |
|                    |                                                                                                                                                                                                                                                                                                                 |
| Instruction format | Bcond disp9                                                                                                                                                                                                                                                                                                     |
| Operation          | if conditions are satisfied then $PC \leftarrow PC + sign-extend$ (disp9)                                                                                                                                                                                                                                       |
| Format             | Format III                                                                                                                                                                                                                                                                                                      |
| Opcode<br>[        | 15 0<br>dddd1011dddcccc                                                                                                                                                                                                                                                                                         |
|                    | ddddddd is the higher 8 bits of disp9.                                                                                                                                                                                                                                                                          |
| Flag               | CY –                                                                                                                                                                                                                                                                                                            |
| 0                  | OV –                                                                                                                                                                                                                                                                                                            |
|                    | S –                                                                                                                                                                                                                                                                                                             |
|                    | Z –                                                                                                                                                                                                                                                                                                             |
|                    | SAT –                                                                                                                                                                                                                                                                                                           |
| Explanation        | Tests each flag of PSW 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.                                                                   |

| Instr    | ruction | Condition Code<br>(CCCC) | Status of Flag         | Branch Condition                  |
|----------|---------|--------------------------|------------------------|-----------------------------------|
| Signed   | BGE     | 1110                     | (S xor OV) = 0         | Greater than or equal signed      |
| integer  | BGT     | 1111                     | ( (S xor OV) or Z) = 0 | Greater than signed               |
|          | BLE     | 0111                     | ( (S xor OV) or Z) = 1 | Less than or equal signed         |
|          | BLT     | 0110                     | (S xor OV) = 1         | Less than signed                  |
| Unsigned | BH      | 1011                     | (CY or Z) = 0          | Higher (Greater than)             |
| integer  | BL      | 0001                     | CY = 1                 | Lower (Less than)                 |
|          | BNH     | 0011                     | (CY or Z) = 1          | Not higher (Less than or equal)   |
|          | BNL     | 1001                     | CY = 0                 | Not lower (Greater than or equal) |
| Common   | BE      | 0010                     | Z = 1                  | Equal                             |
|          | BNE     | 1010                     | Z = 0                  | Not equal                         |
| Others   | BC      | 0001                     | CY = 1                 | Carry                             |
|          | BN      | 0100                     | S = 1                  | Negative                          |
|          | BNC     | 1001                     | CY = 0                 | No carry                          |
|          | BNV     | 1000                     | OV = 0                 | No overflow                       |
|          | BNZ     | 1010                     | Z = 0                  | Not zero                          |
|          | BP      | 1100                     | S = 0                  | Positive                          |
|          | BR      | 0101                     | _                      | Always (unconditional)            |
|          | BSA     | 1101                     | SAT = 1                | Saturated                         |
|          | BV      | 0000                     | OV = 1                 | Overflow                          |
|          | BZ      | 0010                     | Z = 1                  | Zero                              |

| Table 5  | 5-4.                | Bcond  | Instru | ctions |
|----------|---------------------|--------|--------|--------|
| I able v | J- <del>-</del> . I | DCOIIG | mənu   | CUONS  |

### Caution

If executing a conditional branch instruction of a signed integer (BGE, BGT, BLE, or BLT) 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 operations, if an overflow occurs, the S flag is inverted  $(0 \rightarrow 1 \text{ 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 is affected differently when the instruction is a saturate operation, as opposed to an ordinary operation. A branch condition which is an XOR of S and OV flags will therefore have no meaning.

# <Logical operation instruction>

| BSH                | Byte swap halfword                                                                                                                                                                                                                                                                              |  |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                    | Byte Swap Halfword                                                                                                                                                                                                                                                                              |  |
| Instruction format | BSH reg2, reg3                                                                                                                                                                                                                                                                                  |  |
| Operation          | GR [reg3] ← GR [reg2] (23:16)    GR [reg2] (31:24)    GR [reg2] (7:0)    GR [reg2] (15:8)                                                                                                                                                                                                       |  |
| Format             | Format XII                                                                                                                                                                                                                                                                                      |  |
| Opcode             | 15 0 31 16                                                                                                                                                                                                                                                                                      |  |
|                    | rrrr11111100000 wwwww01101000010                                                                                                                                                                                                                                                                |  |
| Flag               | <ul> <li>CY 1 if one or more bytes in result lower halfword is 0; otherwise 0.</li> <li>OV 0</li> <li>S 1 if the MSB of the word data of the operation result is 1; otherwise, 0.</li> <li>Z 1 if the lower halfword data of the operation result is 0; otherwise, 0.</li> <li>SAT -</li> </ul> |  |
| Explanation        | Endian translation.                                                                                                                                                                                                                                                                             |  |

# <Logical operation instruction>

| BSW                | Byte swap word                                                                                                                                                                                                                                                              |  |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                    | Byte Swap Word                                                                                                                                                                                                                                                              |  |
| Instruction format | BSW reg2, reg3                                                                                                                                                                                                                                                              |  |
| Operation          | GR [reg3] ← GR [reg2] (7:0)    GR [reg2] (15:8)    GR [reg2] (23:16)    GR [reg2] (31:24)                                                                                                                                                                                   |  |
| Format             | Format XII                                                                                                                                                                                                                                                                  |  |
| Opcode             | 15     0     31     16       rrrrr11111100000     wwww01101000000                                                                                                                                                                                                           |  |
| Flag               | <ul> <li>CY 1 if one or more bytes in result word is 0; otherwise 0.</li> <li>OV 0</li> <li>S 1 if the MSB of the word data of the operation result is 1; otherwise, 0.</li> <li>Z 1 if the word data of the operation result is 0; otherwise, 0.</li> <li>SAT -</li> </ul> |  |
| Explanation        | Endian translation.                                                                                                                                                                                                                                                         |  |

# <Special instruction>

|                    | Call with table look up                                                                                                                                                                                                                                                                                                                                 |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CALLT              |                                                                                                                                                                                                                                                                                                                                                         |
|                    | Call with Table Look Up                                                                                                                                                                                                                                                                                                                                 |
|                    | Call with Table Look Up                                                                                                                                                                                                                                                                                                                                 |
| Instruction format | CALLT imm6                                                                                                                                                                                                                                                                                                                                              |
| Operation          | $\begin{array}{l} CTPC \leftarrow PC + 2 \ (return \ PC) \\ CTPSW \leftarrow PSW \\ adr \leftarrow CTBP + zero-extend \ (imm6 \ logically \ shift \ left \ by \ 1) \\ PC \leftarrow CTBP + zero-extend \ (Load-memory \ (adr, \ Halfword)) \end{array}$                                                                                                 |
| Format             | Format II                                                                                                                                                                                                                                                                                                                                               |
| Opcode             | 15 0<br>0000001000iiiii                                                                                                                                                                                                                                                                                                                                 |
| Flag               | CY       -         OV       -         S       -         Z       -         SAT       -                                                                                                                                                                                                                                                                   |
| Explanation        | Saves the restore PC and PSW to CTPC and CTPSW. Adds the CTBP and data of imm6, logically shifted left by 1 and zero-extended to word length, to generate a 32-bit table entry address. Then load the halfword entry data, zero-extended to word length, and adds the data and CTBP to generate a 32-bit target address. Then jump to a target address. |
| Caution            | If an interrupt is generated during instruction execution, the execution of that instruction may stop after the end of the read/write cycle. Execution is resumed after returning from the interrupt.                                                                                                                                                   |

# <Bit manipulation instruction>

|                    | Clear bit                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CLR1               |                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                    | Clear Bit                                                                                                                                                                                                                                                                                                                                                                                                           |
| Instruction format | <ul><li>(1) CLR1 bit#3, disp16 [reg1]</li><li>(2) CLR1 reg2, [reg1]</li></ul>                                                                                                                                                                                                                                                                                                                                       |
| Operation          | <ul> <li>(1) adr ← GR [reg1] + sign-extend (disp16)</li> <li>Z flag ← Not (Load-memory-bit (adr, bit#3))</li> <li>Store-memory-bit (adr, bit#3, 0)</li> </ul>                                                                                                                                                                                                                                                       |
|                    | (2) $adr \leftarrow GR [reg1]$<br>Z flag $\leftarrow$ Not (Load-memory-bit (adr, reg2))<br>Store-memory-bit (adr, reg2, 0)                                                                                                                                                                                                                                                                                          |
| Format             | <ul><li>(1) Format VIII</li><li>(2) Format IX</li></ul>                                                                                                                                                                                                                                                                                                                                                             |
| Opcode             | 15     0     31     16       (1)     10bbb111110RRRR     dddddddddddddddddddddddddddddddd                                                                                                                                                                                                                                                                                                                           |
|                    | 15     0     31     16       (2)     rrrrr111111RRRRR     000000011100100                                                                                                                                                                                                                                                                                                                                           |
| Flag               | CY       -         OV       -         S       -         Z       1 if bit specified by operands = 0, 0 if bit specified by operands = 1         SAT       -                                                                                                                                                                                                                                                          |
| Explanation        | <ol> <li>Adds the data of general-purpose register reg1 to the 16-bit displacement, sign-extended to word length, to generate a 32-bit address. Then reads the byte data referenced by the generated address, clears the bit specified by the bit number of 3 bits, and rewrites the original address.</li> <li>Reads the data of general-purpose register reg1 to generate a 32-bit address. Then reads</li> </ol> |
|                    | the byte data referenced by the generated address, clears the bit specified by the data of lower 3 bits of reg2, and rewrites the original address.                                                                                                                                                                                                                                                                 |
| 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.                                                                                                                                                                                                         |

|                    | Conditional move                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CMOV               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                    | Conditional Move                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Instruction format | (1) CMOV cccc, reg1, reg2, reg3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                    | (2) CMOV cccc, imm5, reg2, reg3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Operation          | (1) if conditions are satisfied                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                    | then GR [reg3] $\leftarrow$ GR [reg1]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                    | else GR [reg3] $\leftarrow$ GR [reg2]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                    | (2) if conditions are satisfied                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                    | then GR [reg3] $\leftarrow$ sign-extend (imm5)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                    | else GR [reg3] ← GR [reg2]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Format             | (1) Format XI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                    | (2) Format XII                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Opcode             | 15 0 31 16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                    | (1) rrrr111111RRRRR wwww011001cccc0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                    | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                    | (2) rrrr111111iiii wwww011000cccc0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Flag               | CY –                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                    | OV –                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                    | S –                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                    | Z –                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                    | SAT –                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Explanation        | <ol> <li>The general-purpose register reg3 is set to the data of general-purpose register reg1 if a condition specified by condition code "cccc" is satisfied; otherwise, set to the data of general-purpose register reg2. One of the codes shown in Table 5-5 Condition Codes should be specified as the condition code "cccc".</li> <li>The general-purpose register reg3 is set to the data of 5-bit immediate, sign-extended to word length, if a condition specified by condition code "cccc" is satisfied; otherwise, set to the data of general-purpose register reg2. One of the codes shown in Table 5-5 Condition Codes shown by condition code "cccc" is satisfied; otherwise, set to the data of general-purpose register reg2. One of the codes shown in Table 5-5 Condition Codes should be specified as the condition code "cccc" is satisfied; otherwise, set to the data of general-purpose register reg2. One of the codes shown in Table 5-5 Condition Codes should be specified as the condition code "cccc".</li> </ol> |
|                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Remark             | See SETF instruction.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

| СМР                | Compare register/immediate (5-bit)                                                                                                                                                                                                                                                                                                                                                      |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | Compare                                                                                                                                                                                                                                                                                                                                                                                 |
| Instruction format | <ul><li>(1) CMP reg1, reg2</li><li>(2) CMP imm5, reg2</li></ul>                                                                                                                                                                                                                                                                                                                         |
| Operation          | <ol> <li>(1) result ← GR [reg2] – GR [reg1]</li> <li>(2) result ← GR [reg2] – sign-extend (imm5)</li> </ol>                                                                                                                                                                                                                                                                             |
| Format             | <ul><li>(1) Format I</li><li>(2) Format II</li></ul>                                                                                                                                                                                                                                                                                                                                    |
| Opcode             | 15 0<br>(1) rrrrr001111RRRRR                                                                                                                                                                                                                                                                                                                                                            |
|                    | 15     0       (2)     rrrrr010011iiiii                                                                                                                                                                                                                                                                                                                                                 |
| Flag               | CY 1 if a borrow to MSB occurs; otherwise, 0.                                                                                                                                                                                                                                                                                                                                           |
|                    | OV 1 if overflow occurs; otherwise 0.                                                                                                                                                                                                                                                                                                                                                   |
|                    | S 1 if the operation result is negative; otherwise, 0.                                                                                                                                                                                                                                                                                                                                  |
|                    | Z 1 if the operation result is 0; otherwise, 0.<br>SAT –                                                                                                                                                                                                                                                                                                                                |
| Explanation        | (1) Compares the word data of general-purpose register reg2 with the word data of general-<br>purpose register reg1, and indicates the result by using the flags of PSW. To compare,<br>the contents of general-purpose register reg1 are subtracted from the word data of<br>general-purpose register reg2. The data of general-purpose registers reg1 and reg2 are<br>not affected.   |
|                    | <ul> <li>(2) Compares the word data of general-purpose register reg2 with 5-bit immediate data, sign-extended to word length, and indicates the result by using the flags of PSW. To compare, the contents of the sign-extended immediate data is subtracted from the word data of general-purpose register reg2. The data of general-purpose register reg2 is not affected.</li> </ul> |

# <Special instruction>

| CTRET              | Return from CALLT                                                                                                                                                                                                                                                                                                                                                                          |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CINEI              |                                                                                                                                                                                                                                                                                                                                                                                            |
|                    | Return from CALLT                                                                                                                                                                                                                                                                                                                                                                          |
| Instruction format | CTRET                                                                                                                                                                                                                                                                                                                                                                                      |
| Operation          | $\begin{array}{ll} PC & \leftarrow CTPC \\ PSW & \leftarrow CTPSW \end{array}$                                                                                                                                                                                                                                                                                                             |
| Format             | Format X                                                                                                                                                                                                                                                                                                                                                                                   |
| Opcode             | 15     0     31     16       0000011111100000     000000101000100                                                                                                                                                                                                                                                                                                                          |
| Flag               | <ul> <li>CY Value read from CTPSW is restored.</li> <li>OV Value read from CTPSW is restored.</li> <li>S Value read from CTPSW is restored.</li> <li>Z Value read from CTPSW is restored.</li> <li>SAT Value read from CTPSW is restored.</li> </ul>                                                                                                                                       |
| Explanation        | <ul> <li>Fetches the restore PC and PSW from the appropriate system register and returns from a routine called by CALLT instruction. The operations of this instruction are as follows:</li> <li>(1) The restore PC and PSW are read from the CTPC and CTPSW.</li> <li>(2) Once the PC and PSW are restored to the return values, control is transferred to the return address.</li> </ul> |

# <Debug function instruction>

|                    |                        |                       |                               | Return from debug trap |
|--------------------|------------------------|-----------------------|-------------------------------|------------------------|
| DBRET              |                        |                       |                               |                        |
|                    |                        |                       |                               |                        |
|                    |                        |                       |                               | Return from debug trap |
|                    | DDDET                  |                       |                               |                        |
| Instruction format | DBRET                  |                       |                               |                        |
| Operation          | PC ← DBPC              |                       |                               |                        |
| operation          | $PSW \leftarrow DBPSW$ |                       |                               |                        |
|                    |                        |                       |                               |                        |
| Format             | Format X               |                       |                               |                        |
|                    |                        |                       |                               |                        |
| Opcode             | 15 0                   | 31                    | 16                            |                        |
| -                  | 0000011111100000       | 00000001010001        | 10                            |                        |
|                    |                        |                       |                               |                        |
| Flag               | CY Value read from     | DBPSW is restored.    |                               |                        |
|                    | OV Value read from     | DBPSW is restored.    |                               |                        |
|                    | S Value read from      | DBPSW is restored.    |                               |                        |
|                    | Z Value read from      | DBPSW is restored.    |                               |                        |
|                    | SAT Value read from    | DBPSW is restored.    |                               |                        |
|                    |                        |                       |                               |                        |
| Explanation        | Fetches the restore PC | and PSW from the a    | ppropriate system register    | and returns from debug |
|                    | mode.                  |                       |                               |                        |
|                    |                        |                       |                               |                        |
| Caution            |                        |                       | gging, it is essentially used |                        |
|                    |                        | this instruction, the | refore, use of it in the ap   | plication may cause a  |
|                    | malfunction.           |                       |                               |                        |

# <Debug function instruction>

| DBTRAP             | Debug trap                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                    | Debug trap                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
| Instruction format | DBTRAP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
| Operation          | $\begin{array}{l} DBPC \leftarrow PC + 2 \text{ (restore PC)} \\ DBPSW \leftarrow PSW \\ PSW.NP \leftarrow 1 \\ PSW.EP \leftarrow 1 \\ PSW.ID \leftarrow 1 \\ PC \leftarrow 00000060H \end{array}$                                                                                                                                                                                                                                                                                       |  |
| Format             | Format I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| Opcode             | 15 0<br>1111100001000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| Flag               | CY       -         OV       -         S       -         Z       -         SAT       -                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| Explanation        | Saves the contents of the restore PC (address of the instruction following the DBTRAP instruction) and the PSW to the DBPC and DBPSW, respectively, and sets the NP, EP, and ID flags of PSW to 1.<br>Next, the handler address (00000060H) of the exception trap is set to the PC, and control shifts to the PC. PSW flags other than NP, EP, and ID flags are unaffected.<br>Note that the value saved to the DBPC is the address of the instruction following the DBTRAP instruction. |  |
| Caution            | Because the DBTRAP instruction is for debugging, it is essentially used by debug tools. When<br>a debug tool is using this instruction, therefore, use of it in the application may cause a<br>malfunction.                                                                                                                                                                                                                                                                              |  |

### <Special instruction>

| DI | Disable interrupt |
|----|-------------------|
|    | Disable Interrupt |
|    |                   |

### Instruction format DI

| Operation   | $PSW.ID \gets 1 \text{ (Disables maskable interrupt)}$                                                                       |  |
|-------------|------------------------------------------------------------------------------------------------------------------------------|--|
| Format      | Format X                                                                                                                     |  |
| Opcode      | 15         0         31         16           0000011111100000         000000101100000         16                             |  |
| Flag        | CY       -         OV       -         S       -         Z       -         SAT       -         ID       1                     |  |
| Explanation | Sets the ID flag of the PSW to 1 to disable the acknowledgement of maskable interrupts during execution of this instruction. |  |
| Remark      | Interrupts are not sampled during execution of this instruction. The PSW flag actually                                       |  |

mark Interrupts are not sampled during execution of this instruction. The PSW 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 (NMI) are not affected by this instruction.

### <Special instruction>

| DISPOSE            |                                                                                                                                                                                                                                                                                                                                                                                                                                  | Function dis | pose |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|------|
|                    |                                                                                                                                                                                                                                                                                                                                                                                                                                  | Function Dis | pose |
| Instruction format | <ol> <li>(1) DISPOSE imm5, list12</li> <li>(2) DISPOSE imm5, list12, [reg1]</li> </ol>                                                                                                                                                                                                                                                                                                                                           |              |      |
| Operation          | <ul> <li>(1) sp ← sp + zero-extend (imm5 logically shift left by 2)<br/>GR [reg in list12] ← Load-memory (sp, Word)<br/>sp ← sp + 4<br/>repeat 2 steps above until all regs in list12 are loaded</li> <li>(2) sp ← sp + zero-extend (imm5 logically shift left by 2)<br/>GR [reg in list12] ← Load-memory (sp, Word)<br/>sp ← sp + 4<br/>repeat 2 states above until all regs in list12 are loaded<br/>PC ← GR [reg1]</li> </ul> |              |      |
| Format             | Format XIII                                                                                                                                                                                                                                                                                                                                                                                                                      |              |      |
| Opcode             | 15       0       31       16         (1)       0000011001iiiiiL       LLLLLLLLLL00000         15       0       31       16                                                                                                                                                                                                                                                                                                       |              |      |
|                    | <ul> <li>(2) 0000011001iiiii LLLLLLLLLRRRR</li> <li>RRRRR must not be 00000.</li> <li>In addition, LLLLLLLLLLLLL indicates the value of corresponding bi (list12) (for example, "L" of the bit 21 in the opcode indicates the valist12).</li> <li>The list12 is a 32-bit register list defined as follows.</li> </ul>                                                                                                            | -            |      |
|                    | 31 30 29 28 27 26 25 24 23 22 21 2                                                                                                                                                                                                                                                                                                                                                                                               | 0 1          | 0    |
|                    | r24 r25 r26 r27 r20 r21 r22 r23 r28 r29 r31                                                                                                                                                                                                                                                                                                                                                                                      | _            | r30  |

General-purpose registers (r20 to r31) correspond to the bits 31 to 21 and 0, and the register corresponding to the bit being set (to 1) is specified as the target of manipulation. Any values can be set to bits 20 to 1 since these bits are not corresponding to registers.

| Flag        | CY       -         OV       -         S       -         Z       -         SAT       -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Explanation | <ol> <li>Adds the data of 5-bit immediate imm5, logically shifted left by 2 and zero-extended to word length, to sp. Then pop (load data from the address specified by sp and adds 4 to sp) general-purpose registers listed in list12. Bit 0 of the address is masked to 0.</li> <li>Adds the data of 5-bit immediate imm5, logically shifted left by 2 and zero-extended to word length, to sp. Then pop (load data from the address specified by sp and adds 4 to sp) general-purpose registers listed in list12, transfers control to the address specified by general-purpose register reg1. Bit 0 of the address is masked to 0.</li> </ol>            |
| Remark      | General-purpose registers in list12 are loaded in the downward direction. (r31, r30, r20)<br>The 5-bit immediate imm5 is used to restore a stack frame for auto variables and temporary<br>data.<br>The lower 2-bit of address specified by sp is always masked to 0 even if misaligned access is<br>enabled.<br>If an interrupt occurs before updating the sp, execution is aborted, and the interrupt is<br>processed. Upon returning from the interrupt, the execution is restarted from the beginning,<br>with the return address being the start address of this instruction (sp will retain their original<br>values prior to the start of execution). |
| Caution     | If an interrupt is generated during instruction execution, due to manipulation of the stack, the execution of that instruction may stop after the read/write cycle and register value rewriting are complete. Execution is resumed after returning from the interrupt.                                                                                                                                                                                                                                                                                                                                                                                       |

# DIV

Divide word

Divide Word

| Instruction format | DIV reg1, reg2, reg3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Operation          | GR [reg2] ← GR [reg2] ÷ GR [reg1]<br>GR [reg3] ← GR [reg2] % GR [reg1]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
| Format             | Format XI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| Opcode             | 15         0         31         16           rrrrrllllllRRRR         wwww01011000000         10000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
| Flag               | CY-OV1 if overflow occurs; otherwise, 0.S1 if the operation result is negative; otherwise, 0.Z1 if the operation result is 0; otherwise, 0.SAT-                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
| Explanation        | Divides the word data of general-purpose register reg2 by the word data of general-purpose register reg1, and stores the quotient to general-purpose register reg2, and the remainder to general-purpose register reg3. If the data is divided by 0, overflow occurs, and the quotient is undefined. The data of general-purpose register reg1 is not affected.                                                                                                                                                                                                                                                                                                                                      |  |
| Remark             | Overflow occurs when the maximum negative value (8000000H) 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).<br>If an interrupt occurs while this instruction is executed, execution is aborted, and the interrupt is processed. Upon returning from the interrupt, the execution is restarted from the beginning, with the return address being the start address of this instruction. Also, general-purpose registers reg1 and reg2 will retain their original values prior to the start of execution.<br>If the address of reg2 is the same as the address of reg3, the remainder is stored in reg2 (= reg3). |  |

| DIVH               | Divide halfword                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DIVIT              | Divide Halfword                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Instruction format | <ul><li>(1) DIVH reg1, reg2</li><li>(2) DIVH reg1, reg2, reg3</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Operation          | <ol> <li>GR [reg2] ← GR [reg2] ÷ GR [reg1]</li> <li>GR [reg2] ← GR [reg2] ÷ GR [reg1]</li> <li>GR [reg3] ← GR [reg2] % GR [reg1]</li> </ol>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Format             | <ul><li>(1) Format I</li><li>(2) Format XI</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Opcode             | 15 0<br>(1) rrrr000010RRRR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                    | 15     0     31     16       (2)     rrrrr111111RRRRR     wwwww01010000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Flag               | <ul> <li>CY –</li> <li>OV 1 if overflow occurs; otherwise, 0.</li> <li>S 1 if the operation result is negative; otherwise, 0.</li> <li>Z 1 if the operation result is 0; otherwise, 0.</li> <li>SAT –</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Explanation        | <ol> <li>Divides the word data of general-purpose register reg2 by the lower halfword data of general-purpose register reg1, and stores the quotient to general-purpose register reg2. If the data is divided by 0, overflow occurs, and the quotient is undefined. The data of general-purpose register reg1 is not affected.</li> <li>Divides the word data of general-purpose register reg2 by the lower halfword data of general-purpose register reg1, and stores the quotient to general-purpose register reg2, the remainder to general-purpose register reg3. If the data is divided by 0, overflow occurs, and the quotient is undefined. The data of general-purpose register reg2 is not affected.</li> </ol> |
| Remark             | (1) 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, execution is aborted, and the interrupt is processed. Upon returning from the interrupt, the execution is restarted from the beginning, with the return address being the start address of this instruction. Also, general-purpose registers reg1 and reg2 will retain their original values prior to the start of execution. Do not specify r0 as the destination register reg1 are ignored when division is executed.      |

(2) 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, execution is aborted, and the interrupt is processed. Upon returning from the interrupt, the execution is restarted from the beginning, with the return address being the start address of this instruction. Also, general-purpose registers reg1 and reg2 will retain their original values prior to the start of execution.

The higher 16 bits of general-purpose register reg1 are ignored when division is executed. If the address of reg2 is the same as the address of reg3, the remainder is stored in reg2 (= reg3).

| DIVHU              | Divide halfword unsigned                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                    | Divide Halfword Unsigned                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
| Instruction format | DIVHU reg1, reg2, reg3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
| Operation          | GR [reg2] ← GR [reg2] ÷ GR [reg1]<br>GR [reg3] ← GR [reg2] % GR [reg1]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
| Format             | Format XI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| Opcode             | 15         0         31         16           rrrrr111111RRRRR         wwwww01010000010                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
| Flag               | CY-OV1 if overflow occurs; otherwise, 0.S1 if the operation result is negative; otherwise, 0.Z1 if the operation result is 0; otherwise, 0.SAT-                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
| Explanation        | Divides the word data of general-purpose register reg2 by the lower halfword data of general-<br>purpose register reg1, and stores the quotient to general-purpose register reg2, and the<br>remainder to general-purpose register reg3. If the data is divided by 0, overflow occurs, and<br>the quotient is undefined. The data of general-purpose register reg1 is not affected.                                                                                                                                                                                                                  |  |
| Remark             | Overflow occurs when data is divided by 0 (in which case the quotient is undefined).<br>If an interrupt occurs while this instruction is executed, execution is aborted, and the interrupt<br>is processed. Upon returning from the interrupt, the execution is restarted from the beginning,<br>with the return address being the start address of this instruction. Also, general-purpose<br>registers reg1 and reg2 will retain their original values prior to the start of execution.<br>If the address of reg2 is the same as the address of reg3, the remainder is stored in reg2<br>(= reg3). |  |

# DIVU

Divide word unsigned

**Divide Word Unsigned** 

| Instruction format | DIVU reg1, reg2, reg3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Operation          | GR [reg2] ← GR [reg2] ÷ GR [reg1]<br>GR [reg3] ← GR [reg2] % GR [reg1]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
| Format             | Format XI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| Opcode             | 15     0     31     16       rrrrr111111RRRRR     wwwww01011000010                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
| Flag               | <ul> <li>CY –</li> <li>OV 1 if overflow occurs; otherwise, 0.</li> <li>S 1 if the operation result is negative; otherwise, 0.</li> <li>Z 1 if the operation result is 0; otherwise, 0.</li> <li>SAT –</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                     |  |
| Explanation        | Divides the word data of general-purpose register reg2 by the word data of general-purpose register reg1, and stores the quotient to general-purpose register reg2, and the remainder to general-purpose register reg3. If the data is divided by 0, overflow occurs, and the quotient is undefined. The data of general-purpose register reg1 is not affected.                                                                                                                                                                                                                                      |  |
| Remark             | Overflow occurs when data is divided by 0 (in which case the quotient is undefined).<br>If an interrupt occurs while this instruction is executed, execution is aborted, and the interrupt<br>is processed. Upon returning from the interrupt, the execution is restarted from the beginning,<br>with the return address being the start address of this instruction. Also, general-purpose<br>registers reg1 and reg2 will retain their original values prior to the start of execution.<br>If the address of reg2 is the same as the address of reg3, the remainder is stored in reg2<br>(= reg3). |  |

# <Special instruction>

| EI                    | Enable interrupt |
|-----------------------|------------------|
|                       | Enable Interrupt |
| Instruction format El |                  |

| Instruction format |                                                                                                                              |
|--------------------|------------------------------------------------------------------------------------------------------------------------------|
| Operation          | $PSW.ID \gets 0 \text{ (enables maskable interrupt)}$                                                                        |
| Format             | Format X                                                                                                                     |
| Opcode             | 15     0     31     16       1000011111100000     0000001011000000                                                           |
| Flag               | CY       -         OV       -         S       -         Z       -         SAT       -         ID       0                     |
| Explanation        | Clears 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.                                                                     |

# <Special instruction>

|      | Halt |
|------|------|
| HALT |      |
|      | Halt |
|      |      |

| Instruction format | HALT                                                                                                                                                  |  |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Operation          | Halts                                                                                                                                                 |  |
| Format             | Format X                                                                                                                                              |  |
| Opcode             | 15 0 31 16                                                                                                                                            |  |
|                    | 0000011111100000 000000100100000                                                                                                                      |  |
| Flag               | CY       -         OV       -         S       -         Z       -         SAT       -                                                                 |  |
| 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:                                                                                         |  |
|                    | <ul> <li>Reset input</li> <li>Non-maskable interrupt request (NMI input)</li> <li>Unmasked maskable interrupt request (when ID of PSW = 0)</li> </ul> |  |

If an interrupt is acknowledged during the HALT mode, the address of the following instruction is stored in EIPC or FEPC.

# <Logical operation instruction>

| HSW                | Halfword swap word                                                                                                                                                                                                                                                              |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| пэм                |                                                                                                                                                                                                                                                                                 |
|                    | Halfword Swap Word                                                                                                                                                                                                                                                              |
| Instruction format | HSW reg2, reg3                                                                                                                                                                                                                                                                  |
| Operation          | GR [reg3] ← GR [reg2] (15:0)    GR [reg2] (31:16)                                                                                                                                                                                                                               |
| Format             | Format XII                                                                                                                                                                                                                                                                      |
| Opcode             | 15 0 31 16                                                                                                                                                                                                                                                                      |
|                    | rrrr11111100000 wwww01101000100                                                                                                                                                                                                                                                 |
| Flag               | <ul> <li>CY 1 if one or more halfwords in result word is 0; otherwise 0.</li> <li>OV 0</li> <li>S 1 if the MSB of the word data of the operation result is 1; otherwise, 0.</li> <li>Z 1 if the word data of the operation result is 0; otherwise, 0.</li> <li>SAT -</li> </ul> |
| Explanation        | Endian translation.                                                                                                                                                                                                                                                             |

### <Branch instruction>

| JARL               | Jump and register link                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | Jump and Register Link                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Instruction format | JARL disp22, reg2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Operation          | GR [reg2] $\leftarrow$ PC + 4<br>PC $\leftarrow$ PC + sign-extend (disp22)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Format             | Format V                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Opcode             | 15     0     31     16       rrrrr11110dddddd     ddddddddddddddddd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Flag               | adadadadadadadadadada is the higher 21 bits of disp22.<br>CY –<br>OV –<br>S –<br>Z –<br>SAT –                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Explanation        | Saves the current PC value plus 4 to general-purpose 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 restore PC address to general-purpose register reg2. The JMP instruction, which is equivalent to a subroutine-return instruction, can be used to specify as reg1 the general-purpose register containing the return address saved during the JARL subroutine-call instruction, to restore the program counter. |

### <Branch instruction>

| JMP                | Jump register                                                                                                                                                                                                                                                                                                                                                                  |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | Jump Register                                                                                                                                                                                                                                                                                                                                                                  |
| Instruction format | JMP [reg1]                                                                                                                                                                                                                                                                                                                                                                     |
| Operation          | $PC \leftarrow GR [reg1]$                                                                                                                                                                                                                                                                                                                                                      |
| Format             | Format I                                                                                                                                                                                                                                                                                                                                                                       |
| Opcode             | 15 0<br>0000000011RRRRR                                                                                                                                                                                                                                                                                                                                                        |
| Flag               | CY       -         OV       -         S       -         Z       -         SAT       -                                                                                                                                                                                                                                                                                          |
| Explanation        | Transfers control to the address specified by general-purpose register reg1. Bit 0 of the address is masked to 0.                                                                                                                                                                                                                                                              |
| Remark             | When using this instruction as the subroutine-return instruction, specify the general-purpose 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-purpose register reg2. |

#### <Branch instruction>

| JR                 | Jump relative                                                                                                       |
|--------------------|---------------------------------------------------------------------------------------------------------------------|
|                    | Jump Relative                                                                                                       |
| Instruction format | JR disp22                                                                                                           |
| Operation          | $PC \leftarrow PC + sign-extend (disp22)$                                                                           |
| Format             | Format V                                                                                                            |
| Opcode             | 15 0 31 16                                                                                                          |
|                    | 0000011110dddddd ddddddddddddd                                                                                      |
|                    | ddddddddddddddd is the higher 21 bits of disp22.                                                                    |
| Flag               | CY –                                                                                                                |
|                    | OV –                                                                                                                |
|                    | S –                                                                                                                 |
|                    | Z –<br>SAT –                                                                                                        |
|                    |                                                                                                                     |
| 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.B

Load byte

Load

|                                 | Load                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Instruction format<br>Operation | LD.B disp16 [reg1], reg2<br>adr ← GR [reg1] + sign-extend (disp16)<br>GR [reg2] ← sign-extend (Load-memory (adr, Byte))                                                                                                                                                                                                                                                                                                                                                 |
| Format                          | Format VII                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Opcode                          | 1503116rrrr111000RRRRddddddddddddddddddddddddddddddd                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Flag                            | CY       -         OV       -         S       -         Z       -         SAT       -                                                                                                                                                                                                                                                                                                                                                                                   |
| Explanation                     | Adds the data of general-purpose 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 stored in general-purpose register reg2.                                                                                                                                                                                                             |
| Remark                          | If an interrupt occurs during instruction execution, execution is aborted, and the interrupt is processed. Upon returning from the interrupt, the execution is restarted from the beginning, with the return address being the start address of this instruction. Depending on the resource to be accessed (internal ROM, internal RAM, on-chip peripheral I/O, external memory), the bus cycle may be switched (this will not occur if the same resource is accessed). |

| LD.BU              | Load byte unsigned                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | Load                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Instruction format | LD.BU disp16 [reg1], reg2                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Operation          | adr ← GR [reg1] + sign-extend (disp16)<br>GR [reg2] ← zero-extend (Load-memory (adr, Byte))                                                                                                                                                                                                                                                                                                                                                                             |
| Format             | Format VII                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Opcode             | 15     0     31     16       rrrrr11110bRRRR     dddddddddddddddddd       dddddddddddddddddddddddddddddd       b is the bit 0 of disp16.                                                                                                                                                                                                                                                                                                                                |
| Flag               | CY       -         OV       -         S       -         Z       -         SAT       -                                                                                                                                                                                                                                                                                                                                                                                   |
| Explanation        | Adds the data of general-purpose 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, zero-extended to word length, and stored in general-purpose register reg2.                                                                                                                                                                                                             |
| Remark             | If an interrupt occurs during instruction execution, execution is aborted, and the interrupt is processed. Upon returning from the interrupt, the execution is restarted from the beginning, with the return address being the start address of this instruction. Depending on the resource to be accessed (internal ROM, internal RAM, on-chip peripheral I/O, external memory), the bus cycle may be switched (this will not occur if the same resource is accessed). |

|                    | Load halfword                                                                                                                                                                        |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LD.H               |                                                                                                                                                                                      |
|                    | Load                                                                                                                                                                                 |
|                    |                                                                                                                                                                                      |
| Instruction format | LD.H disp16 [reg1], reg2                                                                                                                                                             |
| Operation          | adr $\leftarrow$ GR [reg1] + sign-extend (disp16)                                                                                                                                    |
|                    | GR [reg2] $\leftarrow$ sign-extend (Load-memory (adr, Halfword))                                                                                                                     |
| Format             | Format VII                                                                                                                                                                           |
| Format             | romat vii                                                                                                                                                                            |
| Opcode             | 15 0 31 16                                                                                                                                                                           |
|                    | rrrr111001RRRRR ddddddddddddd                                                                                                                                                        |
|                    | dddddddddddd is the higher 15 bits of disp16.                                                                                                                                        |
|                    |                                                                                                                                                                                      |
| Flag               | CY –                                                                                                                                                                                 |
|                    | OV –                                                                                                                                                                                 |
|                    | S –<br>7 –                                                                                                                                                                           |
|                    | SAT –                                                                                                                                                                                |
|                    |                                                                                                                                                                                      |
| Explanation        | Adds the data of general-purpose register reg1 to a 16-bit displacement sign-extended to word length to generate a 32-bit address. Halfword data is read from the generated address, |
|                    | sign-extended to word length, and stored in general-purpose register reg2.                                                                                                           |
|                    |                                                                                                                                                                                      |
| Caution            | For notes on misaligned access occurrence, see 3.3 Data Alignment.                                                                                                                   |
| Remark             | If an interrupt occurs during instruction execution, execution is aborted, and the interrupt is                                                                                      |
|                    | processed. Upon returning from the interrupt, the execution is restarted from the beginning,                                                                                         |
|                    | with the return address being the start address of this instruction.                                                                                                                 |
|                    | Depending on the resource to be accessed (internal ROM, internal RAM, on-chip peripheral                                                                                             |
|                    | I/O, external memory), the bus cycle may be switched (this will not occur if the same resource is accessed).                                                                         |
|                    | ,                                                                                                                                                                                    |

| LD.HU              | Load halfword unsigned                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | Load                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Instruction format | LD.HU disp16 [reg1], reg2                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Operation          | adr ← GR [reg1] + sign-extend (disp16)<br>GR [reg2] ← zero-extend (Load-memory (adr, Halfword))                                                                                                                                                                                                                                                                                                                                                                         |
| Format             | Format VII                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Opcode             | 15     0     31     16       rrrrr111111RRRR     ddddddddddddddddddddddd       ddddddddddddddddddddddddddddddd                                                                                                                                                                                                                                                                                                                                                          |
| Flag               | CY       -         OV       -         S       -         Z       -         SAT       -                                                                                                                                                                                                                                                                                                                                                                                   |
| Explanation        | Adds the data of general-purpose register reg1 to a 16-bit displacement sign-extended to word length to generate a 32-bit address. Halfword data is read from the generated address, zero-extended to word length, and stored in general-purpose register reg2.                                                                                                                                                                                                         |
| Caution            | For notes on misaligned access occurrence, see 3.3 Data Alignment.                                                                                                                                                                                                                                                                                                                                                                                                      |
| Remark             | If an interrupt occurs during instruction execution, execution is aborted, and the interrupt is processed. Upon returning from the interrupt, the execution is restarted from the beginning, with the return address being the start address of this instruction. Depending on the resource to be accessed (internal ROM, internal RAM, on-chip peripheral I/O, external memory), the bus cycle may be switched (this will not occur if the same resource is accessed). |

| LD.W               | Load word                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | Load                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Instruction format | LD.W disp16 [reg1], reg2                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Operation          | adr ← GR [reg1] + sign-extend (disp16)<br>GR [reg2] ← Load-memory (adr, Word)                                                                                                                                                                                                                                                                                                                                                                                           |
| Format             | Format VII                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Opcode             | 15     0     31     16       rrrrr111001RRRRR     ddddddddddddddddd                                                                                                                                                                                                                                                                                                                                                                                                     |
|                    | ddddddddddd is the higher 15 bits of disp16.                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Flag               | CY       -         OV       -         S       -         Z       -         SAT       -                                                                                                                                                                                                                                                                                                                                                                                   |
| Explanation        | Adds the data of general-purpose register reg1 to a 16-bit displacement sign-extended to word length to generate a 32-bit address. Word data is read from the generated address.                                                                                                                                                                                                                                                                                        |
| Caution            | For notes on misaligned access occurrence, see 3.3 Data Alignment.                                                                                                                                                                                                                                                                                                                                                                                                      |
| Remark             | If an interrupt occurs during instruction execution, execution is aborted, and the interrupt is processed. Upon returning from the interrupt, the execution is restarted from the beginning, with the return address being the start address of this instruction. Depending on the resource to be accessed (internal ROM, internal RAM, on-chip peripheral I/O, external memory), the bus cycle may be switched (this will not occur if the same resource is accessed). |

# <Special instruction>

|                    | Load to system register                                                                          |
|--------------------|--------------------------------------------------------------------------------------------------|
| LDSR               |                                                                                                  |
|                    |                                                                                                  |
|                    | Load to System Register                                                                          |
| Instruction format | LDSR reg2, regID                                                                                 |
|                    |                                                                                                  |
| Operation          | SR [regID] ← GR [reg2]                                                                           |
| <b>F</b>           |                                                                                                  |
| Format             | Format IX                                                                                        |
| Opcode             | 15 0 31 16                                                                                       |
| •                  | rrrr111111RRRRR 000000000000000000000000                                                         |
|                    |                                                                                                  |
|                    | Caution The source register in this instruction is represented by reg2 for                       |
|                    | convenience of describing its mnemonic . In the opcode, however, the reg1                        |
|                    | field is used for the source register. Unlike other instructions therefore, the                  |
|                    | register specified in the mnemonic description has a different meaning in the                    |
|                    | opcode.                                                                                          |
|                    | rrrrr: regID specification                                                                       |
|                    | RRRRR: reg2 specification                                                                        |
|                    |                                                                                                  |
| Flag               | CY – (See <b>Remark</b> below.)                                                                  |
|                    | OV – (See <b>Remark</b> below.)<br>S – (See <b>Remark</b> below.)                                |
|                    | Z – (See Remark below.)                                                                          |
|                    | SAT – (See <b>Remark</b> below.)                                                                 |
|                    |                                                                                                  |
| Explanation        | Loads the word data of general-purpose register reg2 to a system register specified by the       |
|                    | system register number (regID). The data of general-purpose 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. 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       |
| Vaulion            | system registers which are reserved or write-prohibited is prohibited and will lead to undefined |
|                    | results.                                                                                         |
|                    |                                                                                                  |

| MOV                | Move register/immediate (5-bit)/immediate (32-bit)                                                                                                                                                                                                                      |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | Моче                                                                                                                                                                                                                                                                    |
| Instruction format | <ol> <li>MOV reg1, reg2</li> <li>MOV imm5, reg2</li> <li>MOV imm32, reg1</li> </ol>                                                                                                                                                                                     |
| Operation          | <ol> <li>(1) GR [reg2] ← GR [reg1]</li> <li>(2) GR [reg2] ← sign-extend (imm5)</li> <li>(3) GR [reg1] ← imm32</li> </ol>                                                                                                                                                |
| Format             | <ol> <li>Format I</li> <li>Format II</li> <li>Format VI</li> </ol>                                                                                                                                                                                                      |
| Opcode             | 15     0       (1)     rrrr000000RRRR                                                                                                                                                                                                                                   |
|                    | 15     0       (2)     rrrr010000iiiii                                                                                                                                                                                                                                  |
|                    | 15         0         31         16         47         32           (3)         00000110001RRRR         iiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiii                                                                                                                             |
|                    | <ul> <li>i (bits 31 to 16) refers to the lower 16 bits of 32-bit immediate data.</li> <li>I (bits 47 to 32) refers to the higher 16 bits of 32-bit immediate data.</li> </ul>                                                                                           |
| Flag               | CY       -         OV       -         S       -         Z       -         SAT       -                                                                                                                                                                                   |
| Explanation        | (1) Transfers the word data of general-purpose register reg1 to general-purpose register<br>reg2. The data of general purpose register reg1 is not effected.                                                                                                            |
|                    | <ul> <li>The data of general-purpose register reg1 is not affected.</li> <li>(2) Transfers the value of a 5-bit immediate data, sign-extended to word length, to general-purpose register reg2.</li> <li>Do not specify r0 as the destination register reg2.</li> </ul> |
|                    | <ul><li>(3) Transfers the value of a 32-bit immediate data to general-purpose register reg1.</li></ul>                                                                                                                                                                  |

| MOVEA              | Move effective address                                                                                                                                                                                                                                                                                                                        |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | Move Effective Address                                                                                                                                                                                                                                                                                                                        |
| Instruction format | MOVEA imm16, reg1, reg2                                                                                                                                                                                                                                                                                                                       |
| Operation          | $GR [reg2] \leftarrow GR [reg1] + sign-extend (imm16)$                                                                                                                                                                                                                                                                                        |
| Format             | Format VI                                                                                                                                                                                                                                                                                                                                     |
| Opcode             | 15     0     31     16       rrrrr110001RRRR     iiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiii                                                                                                                                                                                                                                                         |
| Flag               | CY       -         OV       -         S       -         Z       -         SAT       -                                                                                                                                                                                                                                                         |
| Explanation        | Adds the 16-bit immediate data, sign-extended to word length, to the word data of general-<br>purpose register reg1, and stores the result to general-purpose register reg2. The data of<br>general-purpose register reg1 is not affected. The flags are not affected by the addition.<br>Do not specify r0 as the destination register reg2. |
| Remark             | This instruction calculates a 32-bit address and stores the result without affecting the PSW flags.                                                                                                                                                                                                                                           |

# ΜΟΥΗΙ

Move high halfword

Move High Halfword

| Instruction format | MOVHI imm16, reg1, reg2                                                                                                                                                                                                                                                                                                                                                                     |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation          | $GR [reg2] \leftarrow GR [reg1] + (imm16 II 0^{16})$                                                                                                                                                                                                                                                                                                                                        |
| Format             | Format VI                                                                                                                                                                                                                                                                                                                                                                                   |
| Opcode             | 15     0     31     16       rrrrr110010RRRR     iiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiii                                                                                                                                                                                                                                                                                                       |
| Flag               | CY       -         OV       -         S       -         Z       -         SAT       -                                                                                                                                                                                                                                                                                                       |
| Explanation        | Adds a word data, whose higher 16 bits are specified by the 16-bit immediate data and lower<br>16 bits are 0, to the word data of general-purpose register reg1 and stores the result in<br>general-purpose register reg2. The data of general-purpose register reg1 is not affected.<br>The flags are not affected by the addition.<br>Do not specify r0 as the destination register reg2. |
| Remark             | This instruction is used to generate the higher 16 bits of a 32-bit address.                                                                                                                                                                                                                                                                                                                |

 $\star$ 

| MUL                | Multiply word by register/immediate (9-bit)                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | Multiply Word                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Instruction format | <ul><li>(1) MUL reg1, reg2, reg3</li><li>(2) MUL imm9, reg2, reg3</li></ul>                                                                                                                                                                                                                                                                                                                                                                        |
| Operation          | <ul> <li>(1) GR [reg3]    GR [reg2] ← GR [reg2] × GR [reg1]</li> <li>(2) GR [reg3]    GR [reg2] ← GR [reg2] × sign-extend (imm9)</li> </ul>                                                                                                                                                                                                                                                                                                        |
| Format             | <ul><li>(1) Format XI</li><li>(2) Format XII</li></ul>                                                                                                                                                                                                                                                                                                                                                                                             |
| Opcode             | 15     0     31     16       (1)     rrrrr111111RRRRR     wwww01000100000                                                                                                                                                                                                                                                                                                                                                                          |
|                    | 15     0     31     16       (2)     rrrr111111111111111111111111111111111                                                                                                                                                                                                                                                                                                                                                                         |
|                    | iiiii is the lower 5 bits of 9-bit immediate data.<br>IIII is the higher 4 bits of 9-bit immediate data.                                                                                                                                                                                                                                                                                                                                           |
| Flag               | CY       -         OV       -         S       -         Z       -         SAT       -                                                                                                                                                                                                                                                                                                                                                              |
| Explanation        | <ol> <li>Multiplies the word data of general-purpose register reg2 by the word data of general-purpose register reg1, and stores the higher 32 bits of the result (64-bit data) in general-purpose register reg3 and the lower 32 bits in general-purpose register reg2. The data of general-purpose register reg1 is not affected.</li> <li>Multiplies the word data of general-purpose register reg2 by a 9-bit immediate data, sign-</li> </ol> |
|                    | extended to word length, and stores the higher 32 bits of the result (64-bit data) in general-purpose register reg3 and the lower 32 bits in general-purpose register reg2.                                                                                                                                                                                                                                                                        |
| Remark             | If the address of reg2 is the same as the address of reg3, the higher 32 bits of the result are stored in reg2 (= reg3).                                                                                                                                                                                                                                                                                                                           |
| Caution            | Do not specify the same register for general-purpose register reg1 and general-purpose register reg3.                                                                                                                                                                                                                                                                                                                                              |

|                    | Multiply halfword by register/immediate (5-bit)                                                 |
|--------------------|-------------------------------------------------------------------------------------------------|
| MULH               |                                                                                                 |
|                    | Multiply Halfword                                                                               |
| Instruction format |                                                                                                 |
| Instruction format | <ul><li>(1) MULH reg1, reg2</li><li>(2) MULH imm5, reg2</li></ul>                               |
|                    |                                                                                                 |
| Operation          | (1) GR [reg2] (32) ← GR [reg2] (16) × GR [reg1] (16)                                            |
|                    | (2) GR [reg2] ← GR [reg2] × sign-extend (imm5)                                                  |
| Format             | (1) Format I                                                                                    |
|                    | (2) Format II                                                                                   |
| Oneede             |                                                                                                 |
| Opcode             | 15 0<br>(1) rrrr000111RRRR                                                                      |
|                    |                                                                                                 |
|                    | 15 0                                                                                            |
|                    | (2) rrrr010111iiii                                                                              |
|                    |                                                                                                 |
| Flag               | CY –                                                                                            |
|                    | OV –                                                                                            |
|                    | S –                                                                                             |
|                    | Z –<br>SAT –                                                                                    |
|                    |                                                                                                 |
| Explanation        | (1) Multiplies the lower halfword data of general-purpose register reg2 by the halfword data of |
|                    | general-purpose register reg1, and stores the result to general-purpose register reg2 as        |
|                    | word data.<br>The data of general-purpose register reg1 is not affected.                        |
|                    | Do not specify r0 as the destination register reg2.                                             |
|                    | (2) Multiplies the lower halfword data of general-purpose register reg2 by a 5-bit immediate    |
|                    | data, sign-extended to halfword length, and stores the result to general-purpose register       |
|                    | reg2.                                                                                           |
|                    | Do not specify r0 as the destination register reg2.                                             |
| Remark             | The higher 16 bits of general-purpose registers reg1 and reg2 are ignored in this operation.    |

| MULHI              |                         | Multiply halfword by immediate (16-bit) |
|--------------------|-------------------------|-----------------------------------------|
|                    |                         | Multiply Halfword Immediate             |
| Instruction format | MULHI imm16, reg1, reg2 |                                         |

| Operation   | $GR [reg2] \leftarrow GR [reg1] \times imm16$                                                                                                                                                                                                                            |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Format      | Format VI                                                                                                                                                                                                                                                                |
| Opcode      | 15     0     31     16       rrrrrl10111RRRRR     iiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiii                                                                                                                                                                                   |
| Flag        | CY       -         OV       -         S       -         Z       -         SAT       -                                                                                                                                                                                    |
| Explanation | Multiplies the lower halfword data of general-purpose register reg1 by the 16-bit immediate data, and stores the result to general-purpose register reg2. The data of general-purpose register reg1 is not affected. Do not specify r0 as the destination register reg2. |
| Remark      | The higher 16 bits of general-purpose register reg1 are ignored in this operation.                                                                                                                                                                                       |

| MULU               | Multiply word by register/immediate (9-bit)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | Multiply Word Unsigned                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Instruction format | <ol> <li>MULU reg1, reg2, reg3</li> <li>MULU imm9, reg2, reg3</li> </ol>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Operation          | <ol> <li>(1) GR [reg3]    GR [reg2] ← GR [reg2] × GR [reg1]</li> <li>(2) GR [reg3]    GR [reg2] ← GR [reg2] × zero-extend (imm9)</li> </ol>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Format             | <ul><li>(1) Format XI</li><li>(2) Format XII</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Opcode             | 15     0     31     16       (1)     rrrrr111111RRRRR     wwwww01000100010                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                    | 15         0         31         16           (2)         rrrr111111iiii         wwww01001IIII0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                    | iiiii is the lower 5 bits of 9-bit immediate data.<br>IIII is the higher 4 bits of 9-bit immediate data.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Flag               | CY       -         OV       -         S       -         Z       -         SAT       -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Explanation        | <ol> <li>Multiplies the word data of general-purpose register reg2 by the word data of general-purpose register reg1, and stores the higher 32 bits of the result (64-bit data) in general-purpose register reg3 and the lower 32 bits in general-purpose register reg2. The data of general-purpose register reg1 is not affected.</li> <li>Multiplies the word data of general-purpose register reg2 by a 9-bit immediate data, zero-extended to word length, and stores the higher 32 bits of the result (64-bit data) in general-purpose register reg3 and the lower 32 bits in general-purpose register reg2.</li> </ol> |
| Remark             | If the address of reg2 is the same as the address of reg3, the higher 32 bits of the result are stored in reg2 (= reg3).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Caution            | Do not specify the same register for general-purpose register reg1 and general-purpose register reg3.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

# <Special instruction>

| NOP | No operation |
|-----|--------------|
|     | No Operation |

| Instruction format | NOP                                                                                          |
|--------------------|----------------------------------------------------------------------------------------------|
| Operation          | Executes nothing and consumes at least one clock.                                            |
| Format             | Format I                                                                                     |
| Opcode             | 15 0<br>00000000000000                                                                       |
| Flag               | CY       -         OV       -         S       -         Z       -         SAT       -        |
| Explanation        | Executes nothing and consumes at least one clock cycle.                                      |
| Remark             | The contents of the PC are incremented by two. The opcode is the same as that of MOV r0, r0. |

Instruction format NOT reg1, reg2

| NOT | Ν | ΝΟΤ |
|-----|---|-----|
|     | 1 | Not |
|     |   |     |

| Operation   | $GR [reg2] \leftarrow NOT (GR [reg1])$                                                                                                                                                              |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Format      | Format I                                                                                                                                                                                            |
| Opcode      | 15 0<br>rrrr000001RRRRR                                                                                                                                                                             |
| Flag        | <ul> <li>CY –</li> <li>OV 0</li> <li>S 1 if the MSB of the word data of the operation result is 1; otherwise, 0.</li> <li>Z 1 if the operation result is 0; otherwise, 0.</li> <li>SAT –</li> </ul> |
| Explanation | Logically negates (takes the 1's complement of) the word data of general-purpos                                                                                                                     |

Explanation Logically negates (takes the 1's complement of) the word data of general-purpose register reg1, and stores the result to general-purpose register reg2. The data of general-purpose register reg1 is not affected.

# <Bit manipulation instruction>

|                    | NOT bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NOT1               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                    | Not Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Instruction format | <ul><li>(1) NOT1 bit#3, disp16 [reg1]</li><li>(2) NOT1 reg2, [reg1]</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Operation          | <ol> <li>adr ← GR [reg1] + sign-extend (disp16)<br/>Z flag ← Not (Load-memory-bit (adr, bit#3))<br/>Store-memory-bit (adr, bit#3, Z flag)</li> <li>adr ← GR [reg1]<br/>Z flag ← Not (Load-memory-bit (adr, reg2))<br/>Store-memory-bit (adr, reg2, Z flag)</li> </ol>                                                                                                                                                                                                                                                      |
| Format             | <ul><li>(1) Format VIII</li><li>(2) Format IX</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Opcode             | 15       0       31       16         (1)       01bbb11110RRRR       dddddddddddddddddddddddddddddd                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Flag               | CY       -         OV       -         S       -         Z       1 if bit specified by operands = 0, 0 if bit specified by operands = 1         SAT       -                                                                                                                                                                                                                                                                                                                                                                 |
| Explanation        | <ol> <li>Adds the data of general-purpose register reg1 to a 16-bit displacement, sign-extended to word length to generate a 32-bit address. Reads the byte data referenced by the generated address, inverts the bit specified by the 3-bit bit number (0 → 1 or 1 → 0), and rewrites the original address.</li> <li>Reads the data of general-purpose register reg1 to generate a 32-bit address. Reads the byte data referenced by the generated address, inverts the bit specified by the original address.</li> </ol> |
| 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 |
|----|----|
|    | Or |

| Instruction format | OR reg1, reg2                                                                                                                                                                        |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation          | $GR [reg2] \leftarrow GR [reg2] OR GR [reg1]$                                                                                                                                        |
| Format             | Format I                                                                                                                                                                             |
| Opcode             | 15 0<br>rrrr001000RRRR                                                                                                                                                               |
| Flag               | CY-OV0S1 if the MSB of the word data of the operation result is 1; otherwise, 0.Z1 if the operation result is 0; otherwise, 0.SAT-                                                   |
| Explanation        | ORs the word data of general-purpose register reg2 with the word data of general-purpose register reg1, and stores the result to general-purpose register reg2. The data of general- |

purpose register reg1 is not affected.

| <logical operatio<="" th=""><th></th></logical> |                                                                                                                                                                                                     |
|-------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ORI                                             | OR immediate (16-bit)                                                                                                                                                                               |
|                                                 | Or Immediate                                                                                                                                                                                        |
| Instruction format                              | ORI imm16, reg1, reg2                                                                                                                                                                               |
| Operation                                       | GR [reg2] $\leftarrow$ GR [reg1] OR zero-extend (imm16)                                                                                                                                             |
| Format                                          | Format VI                                                                                                                                                                                           |
| Opcode                                          | 15     0     31     16       rrrrr110100RRRR     iiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiii                                                                                                               |
| Flag                                            | <ul> <li>CY –</li> <li>OV 0</li> <li>S 1 if the MSB of the word data of the operation result is 1; otherwise, 0.</li> <li>Z 1 if the operation result is 0; otherwise, 0.</li> <li>SAT –</li> </ul> |

ExplanationORs the word data of general-purpose register reg1 with the value of the 16-bit immediate<br/>data, zero-extended to word length, and stores the result to general-purpose register reg2.<br/>The data of general-purpose register reg1 is not affected.

#### <Special instruction>

| PREPARI            | Function prepare                                                                                                                                                                                                                                                                                                                             |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | Function Prepare                                                                                                                                                                                                                                                                                                                             |
| Instruction format | <ol> <li>PREPARE list12, imm5</li> <li>PREPARE list12, imm5, sp/imm<sup>Note</sup></li> </ol>                                                                                                                                                                                                                                                |
|                    | <b>Note</b> sp/imm is specified by sub-opcode bits 20 and 19.                                                                                                                                                                                                                                                                                |
| Operation          | <ol> <li>Store-memory (sp - 4, GR [reg in list12], Word) sp ← sp - 4<br/>repeat 1 step above until all regs in list12 is stored<br/>sp ← sp - zero-extend (imm5)</li> <li>Store-memory (sp - 4, GR [reg in list12], Word) sp ← sp - 4<br/>repeat 1 step above until all regs in list12 is stored<br/>sp ← sp - zero-extend (imm5)</li> </ol> |
|                    | $ep \leftarrow sp/imm$                                                                                                                                                                                                                                                                                                                       |
| Format             | Format XIII                                                                                                                                                                                                                                                                                                                                  |
| Opcode             | 15     0     31     16       (1)     0000011110iiiiiL     LLLLLLLLL00001                                                                                                                                                                                                                                                                     |
|                    | 15       0       31       16       Optional (47 to 32 or 63 to 32)         (2)       0000011110iiiiiL       LLLLLLLLLLff011       imm16 / imm32                                                                                                                                                                                              |
|                    | In the case of 32-bit immediate data (imm32), bits 47 to 32 are the lower 16 bits of imm32, bits 63 to 48 are the higher 16 bits of imm32.                                                                                                                                                                                                   |
|                    | <ul> <li>ff = 00: load sp to ep</li> <li>ff = 01: load 16-bit immediate data (bits 47 to 32), sign-extended, to ep</li> <li>ff = 10: load 16-bit immediate data (bits 47 to 32), logically shifted left by 16, to ep</li> <li>ff = 11: load 32-bit immediate data (bits 63 to 32) to ep</li> </ul>                                           |
|                    | In addition, LLLLLLLLLL indicates the value of corresponding bit in the register list (list12) (for example, "L" of the bit 21 in the opcode indicates the value of bit 21 of the list12).                                                                                                                                                   |

(for example, "L" of the bit 21 in the opcode indicates the value of bit 21 of the list12). The list12 is a 32-bit register list defined as follows.

| _ | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20 1 | 0   |
|---|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|------|-----|
|   | r24 | r25 | r26 | r27 | r20 | r21 | r22 | r23 | r28 | r29 | r31 | -    | r30 |

General-purpose registers (r20 to r31) correspond to the bits 31 to 21 and 0, and the register corresponding to the bit being set (to 1) is specified as the target of manipulation. Any values can be set to bits 20 to 1 since these bits are not corresponding to registers.

| Flag        | CY –<br>OV –<br>S –<br>Z –<br>SAT –                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Explanation | <ol> <li>Push (subtract 4 from sp and store the data to that address) general-purpose registers listed in list12. Then subtract the data of 5-bit immediate imm5, logically shifted left by 2 and zero-extended to word length, from sp.</li> <li>Push (subtract 4 from sp and store the data to that address) general-purpose registers listed in list12. Then subtract the data of 5-bit immediate imm5, logically shifted left by 2 and zero-extended to word length, from sp.</li> <li>Next, load the data specified by 3rd operand (sp/imm) to ep.</li> </ol>                                                                                                                         |
| Remark      | <ul> <li>General-purpose registers in list12 is stored on the upward direction. (r20, r21, r31)</li> <li>The 5-bit immediate imm5 is used to make a stack frame for auto variables and temporary data.</li> <li>The lower 2 bits of the address specified by sp are always masked to 0 even if misaligned access is enabled.</li> <li>If an interrupt occurs before updating the sp, execution is aborted, and the interrupt is processed. Upon returning from the interrupt, the execution is restarted from the beginning, with the return address being the start address of this instruction (sp and ep will retain their original values prior to the start of execution).</li> </ul> |
| Caution     | If an interrupt is generated during instruction execution, due to manipulation of the stack, the execution of that instruction may stop after the read/write cycle and register value rewriting are complete.                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

# <Special instruction>

|                    | Return from trap or interrupt                                                                                                                                |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RETI               |                                                                                                                                                              |
|                    | Return from Trap or Interrupt                                                                                                                                |
|                    |                                                                                                                                                              |
| Instruction format | RETI                                                                                                                                                         |
|                    |                                                                                                                                                              |
| Operation          | if PSW.EP = 1                                                                                                                                                |
|                    | then $PC \leftarrow EIPC$                                                                                                                                    |
|                    | $PSW \leftarrow EIPSW$<br>else if $PSW.NP = 1$                                                                                                               |
|                    | then PC $\leftarrow$ FEPC                                                                                                                                    |
|                    | $PSW \leftarrow FEPSW$                                                                                                                                       |
|                    | else PC $\leftarrow$ EIPC                                                                                                                                    |
|                    | $PSW \leftarrow EIPSW$                                                                                                                                       |
|                    |                                                                                                                                                              |
| Format             | Format X                                                                                                                                                     |
| Oneede             |                                                                                                                                                              |
| Opcode             | 15         0         31         16           0000011111100000         0000000101000000         0000000101000000                                              |
|                    | 000001111100000 000000101000000                                                                                                                              |
| 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.                                                                                                              |
|                    |                                                                                                                                                              |
| Explanation        | This instruction reads the restore PC and PSW from the appropriate system register, and                                                                      |
|                    | operation returns from a software exception or interrupt routine. The operations of this instruction are as follows:                                         |
|                    |                                                                                                                                                              |
|                    | (1) If the EP flag of the PSW is 1, the restore 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 restore 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 restore PC and PSW                                                                       |
|                    | are read from the EIPC and EIPSW.                                                                                                                            |
|                    | (2) Once the restore PC and PSW values are set to the PC and PSW, the operation returns to<br>the address immediately before the trap or interrupt occurred. |
|                    | ווה מטורסס ווווויסטומנפוץ שפוטופ ווופ וומף טו ווונפווטףו טטטווופט.                                                                                           |

CautionWhen returning from a non-maskable interrupt or software exception routine using the RETI<br/>instruction, the NP and EP flags of PSW must be set accordingly to restore the PC and PSW:

- When returning from non-maskable interrupt routine using the RETI instruction: NP = 1 and EP = 0
- When returning from a software exception routine using the RETI instruction: EP = 1

Use the LDSR instruction for setting the flags.

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 by register/immediate (5-bit)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SAN                | Shift Arithmetic Right                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Instruction format | <ul><li>(1) SAR reg1, reg2</li><li>(2) SAR imm5, reg2</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Operation          | <ol> <li>GR [reg2] ← GR [reg2] arithmetically shift right by GR [reg1]</li> <li>GR [reg2] ← GR [reg2] arithmetically shift right by zero-extend</li> </ol>                                                                                                                                                                                                                                                                                                                                                                                        |
| Format             | <ul><li>(1) Format IX</li><li>(2) Format II</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Opcode             | 15     0     31     16       (1)     rrrrr111111RRRRR     000000010100000                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                    | 15     0       (2)     rrrr010101iiiii                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Flag               | CY 1 if the bit shifted out last is 1; otherwise, 0.<br>However, if the number of shifts is 0, the result is 0.                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                    | OV 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                    | S 1 if the operation result is negative; otherwise, 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                    | Z 1 if the operation result is 0; otherwise, 0.<br>SAT –                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Explanation        | (1) Arithmetically shifts the word data of general-purpose 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-purpose 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-purpose register reg2. If the number of shifts is 0, general-purpose register reg2 retains the same value prior to instruction execution. The data of general-purpose register reg1 is not affected. |
|                    | (2) Arithmetically shifts the word data of general-purpose 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-purpose register reg2. If the number of shifts is 0, general-purpose register reg2 retains the same value prior to                                                                              |

instruction execution.

| SASF               | Shift and set flag condition                                                                                                                                                                                                                                                                                                                                                 |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | Shift and Set Flag Condition                                                                                                                                                                                                                                                                                                                                                 |
| Instruction format | SASF cccc, reg2                                                                                                                                                                                                                                                                                                                                                              |
| Operation          | if conditions are satisfied<br>then GR [reg2] $\leftarrow$ (GR [reg2] Logically shift left by 1) OR 00000001H<br>else GR [reg2] $\leftarrow$ (GR [reg2] Logically shift left by 1) OR 0000000H                                                                                                                                                                               |
| Format             | Format IX                                                                                                                                                                                                                                                                                                                                                                    |
| Opcode             | 15     0     31     16       rrrrrllllllocccc     000000100000000                                                                                                                                                                                                                                                                                                            |
| Flag               | CY       -         OV       -         S       -         Z       -         SAT       -                                                                                                                                                                                                                                                                                        |
| Explanation        | The general-purpose register reg2 is logically shifted left by 1, and its LSB is set to 1 if a condition specified by condition code "cccc" is satisfied; otherwise, the general-purpose register reg2 is logically shifted left by 1, and its LSB is set to 0. One of the codes shown in <b>Table 5-5 Condition Codes</b> should be specified as the condition code "cccc". |
| Remark             | See SETF instruction.                                                                                                                                                                                                                                                                                                                                                        |

|                    | Saturated add register/immediate (5-bit)                                                                                                                                  |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SATADD             |                                                                                                                                                                           |
|                    | Saturated Add                                                                                                                                                             |
| L                  |                                                                                                                                                                           |
| Instruction format | (1) SATADD reg1, reg2                                                                                                                                                     |
|                    | (2) SATADD imm5, reg2                                                                                                                                                     |
| Operation          | (1) GR [reg2] $\leftarrow$ saturated (GR [reg2] + GR [reg1])                                                                                                              |
| oporation          | (2) GR [reg2] $\leftarrow$ saturated (GR [reg2] + sign-extend (imm5))                                                                                                     |
|                    |                                                                                                                                                                           |
| Format             | (1) Format I                                                                                                                                                              |
|                    | (2) Format II                                                                                                                                                             |
| Opcode             | 15 0                                                                                                                                                                      |
| opocue             | (1) rrrr000110RRRR                                                                                                                                                        |
|                    |                                                                                                                                                                           |
|                    | 15 0                                                                                                                                                                      |
|                    | (2) rrrrr01000liiiii                                                                                                                                                      |
| Flag               | CY 1 if a carry occurs from MSB; otherwise, 0.                                                                                                                            |
| Tiag               | 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.                                                                                                                                 |
|                    |                                                                                                                                                                           |
| Explanation        | (1) Adds the word data of general-purpose register reg1 to the word data of general-purpose                                                                               |
|                    | register reg2, and stores the result to general-purpose register reg2. However, if the result exceeds the maximum positive value 7FFFFFFH, 7FFFFFFH is stored in reg2; if |
|                    | the result exceeds the maximum negative value 80000000H, 8000000H is stored in                                                                                            |
|                    | reg2. The SAT flag is set to 1. The data of general-purpose register reg1 is not affected.                                                                                |
|                    | Do not specify r0 as the destination register reg2.                                                                                                                       |
|                    | (2) Adds a 5-bit immediate data, sign-extended to word length, to the word data of general-                                                                               |
|                    | purpose register reg2, and stores the result to general-purpose register reg2. However, if                                                                                |
|                    | the result exceeds the maximum positive value 7FFFFFFH, 7FFFFFFH is stored in                                                                                             |
|                    | reg2; if the result exceeds the maximum negative value 80000000H, 80000000H is stored                                                                                     |
|                    | in reg2. The SAT flag is set to 1.                                                                                                                                        |
|                    | Do not specify r0 as the destination register reg2.                                                                                                                       |
| 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 cleared 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 clear the SAT flag to 0, load data to the PSW by using the LDSR instruction.                                                                                           |
| Jaulion            |                                                                                                                                                                           |

#### Saturated subtract SATSUB Saturated Subtract Instruction format SATSUB reg1, reg2 Operation $GR [reg2] \leftarrow saturated (GR [reg2] - GR [reg1])$ Format I Format Opcode 15 rrrr000101RRRRR CY Flag 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. Ζ 1 if the result of the saturated operation is 0; otherwise, 0. SAT 1 if OV = 1; otherwise, not affected. Explanation Subtracts the word data of general-purpose register reg1 from the word data of generalpurpose register reg2, and stores the result to general-purpose register reg2. However, if the result exceeds the maximum positive value 7FFFFFFH, 7FFFFFFH is stored in reg2; if the result exceeds the maximum negative value 80000000H, 80000000H is stored in reg2. The SAT flag is set to 1. The data of general-purpose register reg1 is not affected. Do not specify r0 as the destination register reg2. 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 cleared 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 clear the SAT flag to 0, load data to the PSW by using the LDSR instruction.

#### Saturated subtract immediate SATSUBI Saturated Subtract Immediate Instruction format SATSUBI imm16, reg1, reg2 Operation GR [reg2] $\leftarrow$ saturated (GR [reg1] – sign-extend (imm16)) Format Format VI Opcode 15 0 31 iiiiiiiiiiiiiiiii rrrr110011RRRRR CY Flag 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. Ζ 1 if the result of the saturated operation is 0; otherwise, 0. SAT 1 if OV = 1; otherwise, not affected. Explanation Subtracts the 16-bit immediate data, sign-extended to word length, from the word data of general-purpose register reg1, and stores the result to general-purpose register reg2. However, if the result exceeds the maximum positive value 7FFFFFFH, 7FFFFFFH is stored in reg2; if the result exceeds the maximum negative value 80000000H, 80000000H is stored in reg2. The SAT flag is set to 1. The data of general-purpose register reg1 is not affected. Do not specify r0 as the destination register reg2. 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 cleared 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 clear the SAT flag to 0, load data to the PSW by using the LDSR instruction.

# SATSUBR

Saturated subtract reverse

Saturated Subtract Reverse

| Instruction format | SATSUBR reg1, reg2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation          | $GR [reg2] \leftarrow saturated (GR [reg1] - GR [reg2])$                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Format             | Format I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Opcode<br>         | 15 0<br>rrrr000100RRRRR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Flag               | <ul> <li>CY 1 if a borrow to MSB occurs; otherwise, 0.</li> <li>OV 1 if overflow occurs; otherwise, 0.</li> <li>S 1 if the result of the saturated operation is negative; otherwise, 0.</li> <li>Z 1 if the result of the saturated operation is 0; otherwise, 0.</li> <li>SAT 1 if OV = 1; otherwise, not affected.</li> </ul>                                                                                                                                                                                         |
| Explanation        | Subtracts the word data of general-purpose register reg2 from the word data of general-<br>purpose register reg1, and stores the result to general-purpose register reg2. However, if the<br>result exceeds the maximum positive value 7FFFFFFH, 7FFFFFFH is stored in reg2; if the<br>result exceeds the maximum negative value 80000000H, 80000000H is stored in reg2. The<br>SAT flag is set to 1. The data of general-purpose register reg1 is not affected.<br>Do not specify r0 as the destination register reg2. |
| 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 cleared 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 clear the SAT flag to 0, load data to the PSW by using the LDSR instruction.                                                                                                                                                                                                                                                                                                                                                                                                                                         |

# <Bit manipulation instruction>

| 0574               | Set bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SET1               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                    | Set Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Instruction format | <ul><li>(1) SET1 bit#3, disp16 [reg1]</li><li>(2) SET1 reg2, [reg1]</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Operation          | <ul> <li>adr ← GR [reg1] + sign-extend (disp16)</li> <li>Z flag ← Not (Load-memory-bit (adr, bit#3))</li> <li>Store-memory-bit (adr, bit#3, 1)</li> </ul>                                                                                                                                                                                                                                                                                                                                                              |
|                    | (2) adr $\leftarrow$ GR [reg1]<br>Z flag $\leftarrow$ Not (Load-memory-bit (adr, reg2))<br>Store-memory-bit (adr, reg2, 1)                                                                                                                                                                                                                                                                                                                                                                                             |
| Format             | <ul><li>(1) Format VIII</li><li>(2) Format IX</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Opcode             | 15     0     31     16       (1)     00bbb111110RRRRR     dddddddddddddddddddddddddddddddd                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                    | 15     0     31     16       (2)     rrrrr111111RRRRR     000000011100000                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Flag               | CY       -         OV       -         S       -         Z       1 if bit specified by operands = 0, 0 if bit specified by operands = 1         SAT       -                                                                                                                                                                                                                                                                                                                                                             |
| Explanation        | <ol> <li>Adds the 16-bit displacement, sign-extended to word length, to the data of general-<br/>purpose register reg1 to generate a 32-bit address. Reads the byte data referenced by the<br/>generated address, sets the bit specified by the 3-bit bit number (to 1), and rewrites the<br/>original address.</li> <li>Reads the data of general-purpose register reg1 to generate a 32-bit address. Reads the<br/>byte data referenced by the generated address, sets the bit specified by the 3-bit bit</li> </ol> |
| Remark             | number (to 1), and rewrites the original address.<br>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.                                                                                                                                                                                                                                                        |

# SETF

Set flag condition

Set Flag Condition

| Instruction format | SETF cccc, reg2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation          | if conditions are satisfied<br>then GR [reg2] $\leftarrow$ 00000001H<br>else GR [reg2] $\leftarrow$ 00000000H                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Format             | Format IX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Opcode             | 15         0         31         16           rrrrrlllllllocccc         000000000000000000000000000000000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Flag               | CY       -         OV       -         S       -         Z       -         SAT       -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Explanation        | The general-purpose register reg2 is set to 1 if a condition specified by condition code "cccc" is satisfied; otherwise, 0 are stored in the register. One of the codes shown in <b>Table 5-5 Condition Codes</b> 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<br>If A of statement if (A) in C language consists of two or more condition clauses (a1, a2, a3,<br>and so on), it is usually translated to a sequence of if (a1) then, if (a2) then. The object<br>code executes "conditional branch" by checking the result of evaluation equivalent to an.<br>Since a pipeline processor takes more time to execute "condition judgment" + "branch"<br>than to execute an ordinary operation, the result of evaluating each condition clause if (an)<br>is stored in register Ra. By performing a logical operation to Ran after all the condition<br>clauses have been evaluated, the delay due to the pipeline can be prevented. |
|                    | (2) Double-length operation<br>To execute a double-length operation such as Add with Carry, the result of the CY flag<br>can be stored in general-purpose register reg2. Therefore, a carry from the lower bits can<br>be expressed as a numeric value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

| Condition Code<br>(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 (unconditional) |
| 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  |

#### Table 5-5. Condition Codes

| <logical operatio<="" th=""><th></th></logical> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SHL                                             | Shift logical left by register/immediate (5-bit)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                                                 | Shift Logical Left                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Instruction format                              | <ul><li>(1) SHL reg1, reg2</li><li>(2) SHL imm5, reg2</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Operation                                       | <ol> <li>GR [reg2] ← GR [reg2] logically shift left by GR [reg1]</li> <li>GR [reg2] ← GR [reg2] logically shift left by zero-extend (imm5)</li> </ol>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Format                                          | <ul><li>(1) Format IX</li><li>(2) Format II</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Opcode                                          | 15         0         31         16           (1)         rrrr111111RRRR         000000011000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                                 | 15     0       (2)     rrrr010110iiiii                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 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.<br>OV 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                                 | S 1 if the operation result is negative; otherwise, 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                                 | Z 1 if the operation result is 0; otherwise, 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                                 | SAT –                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Explanation                                     | <ol> <li>Logically shifts the word data of general-purpose 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-purpose register reg1 (0 is shifted to the LSB side), and then writes the result to general-purpose register reg2. If the number of shifts is 0, general-purpose register reg2 retains the same value prior to instruction execution. The data of general-purpose register reg1 is not affected.</li> <li>Logically shifts the word data of general-purpose 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-purpose</li> </ol> |
|                                                 | word length (0 is shifted to the LSB side), and then writes the result to general-purpose                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

prior to instruction execution.

register reg2. If the number of shifts is 0, general-purpose register reg2 retains the value

| SHR                | Shift logical right by register/immediate (5-bit)                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | Shift Logical Right                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Instruction format | <ul><li>(1) SHR reg1, reg2</li><li>(2) SHR imm5, reg2</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Operation          | <ol> <li>GR [reg2] ← GR [reg2] logically shift right by GR [reg1]</li> <li>GR [reg2] ← GR [reg2] logically shift right by zero-extend (imm5)</li> </ol>                                                                                                                                                                                                                                                                                                                                                      |
| Format             | <ul><li>(1) Format IX</li><li>(2) Format II</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Opcode             | 15         0         31         16           (1)         rrrr111111RRRRR         000000000000000000000000000000000000                                                                                                                                                                                                                                                                                                                                                                                        |
|                    | 15 0<br>(2) rrrr010100iiiii                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 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.<br>OV 0                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                    | S 1 if the operation result is negative; otherwise, 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                    | Z 1 if the operation result is 0; otherwise, 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                    | SAT –                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Explanation        | (1) Logically shifts the word data of general-purpose register reg2 to the right by 'n' positions<br>where 'n' is a value from 0 to +31, specified by the lower 5 bits of general-purpose register<br>reg1 (0 is shifted to the MSB side). This instruction then writes the result to general-<br>purpose register reg2. If the number of shifts is 0, general-purpose register reg2 retains<br>the same value prior to instruction execution. The data of general-purpose register reg1 is<br>not affected. |
|                    | (2) Logically shifts the word data of general-purpose 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-purpose register reg2. If the number of shifts is 0, general-purpose register reg2                                                                                                                             |

retains the same value prior to instruction execution.

# Short format load byte SLD.B Load Instruction format SLD.B disp7 [ep], reg2 Operation adr $\leftarrow$ ep + zero-extend (disp7) GR [reg2] ← sign-extend (Load-memory (adr, Byte)) Format Format IV Opcode 15 0 rrrrr0110ddddddd Flag CY \_ OV S \_ Ζ \_ SAT Explanation 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 in reg2. Remark If an interrupt occurs during instruction execution, execution is aborted, and the interrupt is processed. Upon returning from the interrupt, the execution is restarted from the beginning, with the return address being the start address of this instruction. Depending on the resource to be accessed (internal ROM, internal RAM, on-chip peripheral I/O, external memory), the bus cycle may be switched (this will not occur if the same resource is accessed).

Caution If an interrupt is generated during instruction execution, the execution of that instruction may stop after the end of the read/write cycle. In this case, the instruction is re-executed after returning from the interrupt. Therefore, except in cases when clearly no interrupt is generated, the LD instruction should be used for accessing I/O, FIFO types, or other resources whose status is changed by the read cycle (the bus cycle is not re-executed even if an interrupt is generated while the LD or store instruction is being executed).

| SLD.BU             | Short format load byte unsigned                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | Load                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Instruction format | SLD.BU disp4 [ep], reg2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Operation          | adr ← ep + zero-extend (disp4)<br>GR [reg2] ← zero-extend (Load-memory (adr, Byte))                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Format             | Format IV                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Opcode             | 15 0<br>rrrr0000110dddd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                    | rrrr must not be 00000.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Flag               | CY       -         OV       -         S       -         Z       -         SAT       -                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Explanation        | Adds the 4-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, zero-extended to word length, and stored in reg2.                                                                                                                                                                                                                                                                                                                                          |
| Remark             | If an interrupt occurs during instruction execution, execution is aborted, and the interrupt is processed. Upon returning from the interrupt, the execution is restarted from the beginning, with the return address being the start address of this instruction. Depending on the resource to be accessed (internal ROM, internal RAM, on-chip peripheral I/O, external memory), the bus cycle may be switched (this will not occur if the same resource is accessed).                                                                                  |
| Caution            | If an interrupt is generated during instruction execution, the execution of that instruction may stop after the end of the read/write cycle. In this case, the instruction is re-executed after returning from the interrupt. Therefore, except in cases when clearly no interrupt is generated, the LD instruction should be used for accessing I/O, FIFO types, or other resources whose status is changed by the read cycle (the bus cycle is not re-executed even if an interrupt is generated while the LD or store instruction is being executed). |

# <Load instruction>

|                    | Short format load halfword                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SLD.H              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                    | Load                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Instruction format | SLD.H disp8 [ep], reg2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Operation          | adr $\leftarrow$ ep + zero-extend (disp8)<br>GR [reg2] $\leftarrow$ sign-extend (Load-memory (adr, Halfword))                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Format             | Format IV                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Opcode             | 15 0<br>rrrrr1000dddddd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                    | dddddd is the higher 7 bits of disp8.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Flag               | CY       -         OV       -         S       -         Z       -         SAT       -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Explanation        | Adds the 8-bit displacement, zero-extended to word length, to the element pointer to generate a 32-bit address. Halfword data is read from the generated address, sign-extended to word length, and stored in reg2.                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Remark             | If an interrupt occurs during instruction execution, execution is aborted, and the interrupt is processed. Upon returning from the interrupt, the execution is restarted from the beginning, with the return address being the start address of this instruction. Depending on the resource to be accessed (internal ROM, internal RAM, on-chip peripheral I/O, external memory), the bus cycle may be switched (this will not occur if the same resource is accessed).                                                                                                                                                                      |
| Caution            | For notes on misaligned access occurrence, see <b>3.3 Data Alignment</b> .<br>Also, if an interrupt is generated during instruction execution, the execution of that instruction may stop after the end of the read/write cycle. In this case, the instruction is re-executed after returning from the interrupt. Therefore, except in cases when clearly no interrupt is generated, the LD instruction should be used for accessing I/O, FIFO types, or other resources whose status is changed by the read cycle (the bus cycle is not re-executed even if an interrupt is generated while the LD or store instruction is being executed). |

### <Load instruction>

| SLD.HU             | Short format load halfword unsigned                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | Load                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Instruction format | SLD.HU disp5 [ep], reg2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Operation          | adr ← ep + zero-extend (disp5)<br>GR [reg2] ← zero-extend (Load-memory (adr, Halfword))                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Format             | Format IV                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Opcode             | 15 0<br>rrrr0000111dddd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                    | dddd is the higher 4 bits of disp5. rrrrr must not be 00000.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Flag               | CY       -         OV       -         S       -         Z       -         SAT       -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Explanation        | Adds the 5-bit displacement, zero-extended to word length, to the element pointer to generate a 32-bit address. Halfword data is read from the generated address, zero-extended to word length, and stored in reg2.                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Remark             | If an interrupt occurs during instruction execution, execution is aborted, and the interrupt is processed. Upon returning from the interrupt, the execution is restarted from the beginning, with the return address being the start address of this instruction. Depending on the resource to be accessed (internal ROM, internal RAM, on-chip peripheral I/O, external memory), the bus cycle may be switched (this will not occur if the same resource is accessed).                                                                                                                                                                      |
| Caution            | For notes on misaligned access occurrence, see <b>3.3 Data Alignment</b> .<br>Also, if an interrupt is generated during instruction execution, the execution of that instruction may stop after the end of the read/write cycle. In this case, the instruction is re-executed after returning from the interrupt. Therefore, except in cases when clearly no interrupt is generated, the LD instruction should be used for accessing I/O, FIFO types, or other resources whose status is changed by the read cycle (the bus cycle is not re-executed even if an interrupt is generated while the LD or store instruction is being executed). |

# <Load instruction>

| <b>•</b> •••••     | Short format load word                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SLD.W              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                    | Load                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Instruction format | SLD.W disp8 [ep], reg2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Operation          | adr ← ep + zero-extend (disp8)<br>GR [reg2] ← Load-memory (adr, Word)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Format             | Format IV                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Opcode             | 15 0<br>rrrr1010dddddd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                    | ddddd is the higher 6 bits of disp8.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Flag               | CY       -         OV       -         S       -         Z       -         SAT       -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Explanation        | 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 the generated address, and stored in reg2.                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Remark             | If an interrupt occurs during instruction execution, execution is aborted, and the interrupt is processed. Upon returning from the interrupt, the execution is restarted from the beginning, with the return address being the start address of this instruction. Depending on the resource to be accessed (internal ROM, internal RAM, on-chip peripheral I/O, external memory), the bus cycle may be switched (this will not occur if the same resource is accessed).                                                                                                                                                                      |
| Caution            | For notes on misaligned access occurrence, see <b>3.3 Data Alignment</b> .<br>Also, if an interrupt is generated during instruction execution, the execution of that instruction may stop after the end of the read/write cycle. In this case, the instruction is re-executed after returning from the interrupt. Therefore, except in cases when clearly no interrupt is generated, the LD instruction should be used for accessing I/O, FIFO types, or other resources whose status is changed by the read cycle (the bus cycle is not re-executed even if an interrupt is generated while the LD or store instruction is being executed). |

# Short format store byte SST.B Store Instruction format SST.B reg2, disp7 [ep] Operation adr $\leftarrow$ ep + zero-extend (disp7) Store-memory (adr, GR [reg2], Byte) Format Format IV Opcode 15 0 rrrrr0111ddddddd Flag CY \_ OV S Ζ \_ SAT \_ Explanation 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 in the generated address. Remark If an interrupt occurs during instruction execution, execution is aborted, and the interrupt is processed. Upon returning from the interrupt, the execution is restarted from the beginning, with the return address being the start address of this instruction. Depending on the resource to be accessed (internal ROM, internal RAM, on-chip peripheral I/O, external memory), the bus cycle may be switched (this will not occur if the same resource is accessed).

| SST.H              | Short format store halfword                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | Store                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Instruction format | SST.H reg2, disp8 [ep]                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Operation          | adr ← ep + zero-extend (disp8)<br>Store-memory (adr, GR [reg2], Halfword)                                                                                                                                                                                                                                                                                                                                                                                               |
| Format             | Format IV                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Opcode             | 15 0<br>rrrr1001dddddd                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                    | dddddd is the higher 7 bits of disp8.                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Flag               | CY       -         OV       -         S       -         Z       -         SAT       -                                                                                                                                                                                                                                                                                                                                                                                   |
| Explanation        | Adds the 8-bit displacement, zero-extended to word length, to the element pointer to generate a 32-bit address, and stores the lower halfword data of reg2 in the generated address.                                                                                                                                                                                                                                                                                    |
| Caution            | For notes on misaligned access occurrence, see 3.3 Data Alignment.                                                                                                                                                                                                                                                                                                                                                                                                      |
| Remark             | If an interrupt occurs during instruction execution, execution is aborted, and the interrupt is processed. Upon returning from the interrupt, the execution is restarted from the beginning, with the return address being the start address of this instruction. Depending on the resource to be accessed (internal ROM, internal RAM, on-chip peripheral I/O, external memory), the bus cycle may be switched (this will not occur if the same resource is accessed). |

|                    | Short format store word                                                                         |
|--------------------|-------------------------------------------------------------------------------------------------|
| SST.W              |                                                                                                 |
|                    | Store                                                                                           |
|                    |                                                                                                 |
| Instruction format | SST.W reg2, disp8 [ep]                                                                          |
| Operation          | $adr \leftarrow ep + zero-extend (disp8)$                                                       |
|                    | Store-memory (adr, GR [reg2], Word)                                                             |
| Format             | Format IV                                                                                       |
|                    |                                                                                                 |
| Opcode             |                                                                                                 |
|                    | rrrr1010ddddd1                                                                                  |
|                    | ddddd is the higher 6 bits of disp8.                                                            |
| Flog               | CY –                                                                                            |
| Flag               | OV –                                                                                            |
|                    | S –                                                                                             |
|                    | Z –                                                                                             |
|                    | SAT –                                                                                           |
| Explanation        | 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 in the generated address.                    |
| Caution            | For notes on misaligned access occurrence, see 3.3 Data Alignment.                              |
| Remark             | If an interrupt occurs during instruction execution, execution is aborted, and the interrupt is |
|                    | processed. Upon returning from the interrupt, the execution is restarted from the beginning,    |
|                    | with the return address being the start address of this instruction.                            |
|                    | Depending on the resource to be accessed (internal ROM, internal RAM, on-chip peripheral        |
|                    | I/O, external memory), the bus cycle may be switched (this will not occur if the same resource  |
|                    | is accessed).                                                                                   |

| ST.B | Sto | ore byte |
|------|-----|----------|
|      |     | Store    |

| Instruction format | ST.B reg2, disp16 [reg1]                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation          | adr ← GR [reg1] + sign-extend (disp16)<br>Store-memory (adr, GR [reg2], Byte)                                                                                                                                                                                                                                                                                                                                                                                           |
| Format             | Format VII                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Opcode             | 15         0         31         16           rrrrr111010RRRR         dddddddddddddddddddddddddddd                                                                                                                                                                                                                                                                                                                                                                       |
| Flag               | CY       -         OV       -         S       -         Z       -         SAT       -                                                                                                                                                                                                                                                                                                                                                                                   |
| Explanation        | Adds the 16-bit displacement, sign-extended to word length, to the data of general-purpose register reg1 to generate a 32-bit address, and stores the lowest byte data of general-purpose register reg2 to the generated address.                                                                                                                                                                                                                                       |
| Remark             | If an interrupt occurs during instruction execution, execution is aborted, and the interrupt is processed. Upon returning from the interrupt, the execution is restarted from the beginning, with the return address being the start address of this instruction. Depending on the resource to be accessed (internal ROM, internal RAM, on-chip peripheral I/O, external memory), the bus cycle may be switched (this will not occur if the same resource is accessed). |

|                    | Store halfword                                                                                                                                                   |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ST.H               |                                                                                                                                                                  |
|                    | Store                                                                                                                                                            |
|                    |                                                                                                                                                                  |
| Instruction format | ST.H reg2, disp16 [reg1]                                                                                                                                         |
|                    |                                                                                                                                                                  |
| Operation          | adr ← GR [reg1] + sign-extend (disp16)<br>Store-memory (adr, GR [reg2], Halfword)                                                                                |
|                    | Store-memory (aut, Gr [regz], hallword)                                                                                                                          |
| Format             | Format VII                                                                                                                                                       |
|                    |                                                                                                                                                                  |
| Opcode             | 15 0 31 16                                                                                                                                                       |
|                    | rrrr111011RRRRR dddddddddddd                                                                                                                                     |
|                    |                                                                                                                                                                  |
|                    | dadadadadadad is the higher 15 bits of disp16.                                                                                                                   |
| Flag               | CY –                                                                                                                                                             |
|                    | OV –                                                                                                                                                             |
|                    | S –                                                                                                                                                              |
|                    | Z –                                                                                                                                                              |
|                    | SAT –                                                                                                                                                            |
|                    |                                                                                                                                                                  |
| Explanation        | Adds the 16-bit displacement, sign-extended to word length, to the data of general-purpose                                                                       |
|                    | register reg1 to generate a 32-bit address, and stores the lower halfword data of general-<br>purpose register reg2 in the generated address.                    |
|                    | pulpose register regz in the generated address.                                                                                                                  |
| Caution            | For notes on misaligned access occurrence, see 3.3 Data Alignment.                                                                                               |
|                    |                                                                                                                                                                  |
| Remark             | If an interrupt occurs during instruction execution, execution is aborted, and the interrupt is                                                                  |
|                    | processed. Upon returning from the interrupt, the execution is restarted from the beginning,                                                                     |
|                    | with the return address being the start address of this instruction.<br>Depending on the resource to be accessed (internal ROM, internal RAM, on-chip peripheral |
|                    | I/O, external memory), the bus cycle may be switched (this will not occur if the same resource                                                                   |
|                    | is accessed).                                                                                                                                                    |
|                    |                                                                                                                                                                  |

| ST.W               | Store word                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | Store                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Instruction format | ST.W reg2, disp16 [reg1]                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Operation          | adr $\leftarrow$ GR [reg1] + sign-extend (disp16)<br>Store-memory (adr, GR [reg2], Word)                                                                                                                                                                                                                                                                                                                                                                                |
| Format             | Format VII                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Opcode             | 1503116rrrrr111011RRRRRdddddddddddddddddddddddd                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                    | dddddddddddd is the higher 15 bits of disp16.                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Flag               | CY       -         OV       -         S       -         Z       -         SAT       -                                                                                                                                                                                                                                                                                                                                                                                   |
| Explanation        | Adds the 16-bit displacement, sign-extended to word length, to the data of general-purpose register reg1 to generate a 32-bit address, and stores the word data of general-purpose register reg2 in the generated address.                                                                                                                                                                                                                                              |
| Caution            | For notes on misaligned access occurrence, see 3.3 Data Alignment.                                                                                                                                                                                                                                                                                                                                                                                                      |
| Remark             | If an interrupt occurs during instruction execution, execution is aborted, and the interrupt is processed. Upon returning from the interrupt, the execution is restarted from the beginning, with the return address being the start address of this instruction. Depending on the resource to be accessed (internal ROM, internal RAM, on-chip peripheral I/O, external memory), the bus cycle may be switched (this will not occur if the same resource is accessed). |

### <Special instruction>

# Store contents of system register Store Contents of System Register Instruction format STSR regID, reg2

| Operation   | $GR [reg2] \leftarrow SR [regID]$                                                                                                                                                |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Format      | Format IX                                                                                                                                                                        |
| Opcode      | 15         0         31         16           rrrrr111111RRRRR         000000000000000000000000000000000000                                                                       |
| Flag        | CY       -         OV       -         S       -         Z       -         SAT       -                                                                                            |
| Explanation | Stores the contents of a system register specified by system register number (regID) to general-purpose register reg2. The contents of the system register are not affected.     |
| Caution     | The system register number regID is a number which identifies a system register. Accessing a system register which is reserved is prohibited and will lead to undefined results. |

| <logical operatio<="" th=""><th>n instruction&gt;</th><th></th></logical> | n instruction>                                                                                                                                                                                                                                            |        |
|---------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|
| SUB                                                                       | Sut                                                                                                                                                                                                                                                       | otract |
|                                                                           | Sub                                                                                                                                                                                                                                                       | otract |
| Instruction format                                                        | SUB reg1, reg2                                                                                                                                                                                                                                            |        |
| Operation                                                                 | $GR [reg2] \leftarrow GR [reg2] - GR [reg1]$                                                                                                                                                                                                              |        |
| Format                                                                    | Format I                                                                                                                                                                                                                                                  |        |
| Opcode                                                                    | 15 0<br>rrrrr001101RRRRR                                                                                                                                                                                                                                  |        |
| Flag                                                                      | <ul> <li>CY 1 if a borrow to MSB occurs; otherwise, 0.</li> <li>OV 1 if overflow occurs; otherwise, 0.</li> <li>S 1 if the operation result is negative; otherwise, 0.</li> <li>Z 1 if the operation result is 0; otherwise, 0.</li> <li>SAT -</li> </ul> |        |
| Explanation                                                               | Subtracts the word data of general-purpose register reg1 from the word data of gen                                                                                                                                                                        |        |

xplanationSubtracts the word data of general-purpose register reg1 from the word data of general-<br/>purpose register reg2, and stores the result to general-purpose register reg2. The data of<br/>general-purpose register reg1 is not affected.

# SUBR

Subtract reverse

Subtract Reverse

| Instruction format | SUBR reg1, reg2                                                                                                                                                                                                                                           |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation          | $GR [reg2] \leftarrow GR [reg1] - GR [reg2]$                                                                                                                                                                                                              |
| Format             | Format I                                                                                                                                                                                                                                                  |
| Opcode             | 15 0<br>rrrr001100RRRR                                                                                                                                                                                                                                    |
| Flag               | <ul> <li>CY 1 if a borrow to MSB occurs; otherwise, 0.</li> <li>OV 1 if overflow occurs; otherwise, 0.</li> <li>S 1 if the operation result is negative; otherwise, 0.</li> <li>Z 1 if the operation result is 0; otherwise, 0.</li> <li>SAT -</li> </ul> |
| Explanation        | Subtracts the word data of general-purpose register reg2 from the word data of general-<br>purpose register reg1, and stores the result to general-purpose register reg2. The data of<br>general-purpose register reg1 is not affected.                   |

# <Special instruction>

| SWITCH             | Jump with table look up                                                                                                                                                                                             |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | Jump with Table Look Up                                                                                                                                                                                             |
| Instruction format | SWITCH reg1                                                                                                                                                                                                         |
| Operation          | adr $\leftarrow$ (PC + 2) + (GR [reg1] logically shift left by 1)<br>PC $\leftarrow$ (PC + 2) + (sign-extend (Load-memory (adr, Halfword))) logically shift left by 1                                               |
| Format             | Format I                                                                                                                                                                                                            |
| Opcode             | 15 0<br>0000000010RRRR                                                                                                                                                                                              |
| Flag               | CY –<br>OV –<br>S –                                                                                                                                                                                                 |
|                    | Z –<br>SAT –                                                                                                                                                                                                        |
| Explanation        | <1> Adds the table entry address (address following SWITCH instruction) and data of general-purpose register reg1 logically shifted left by 1, and generates 32-bit table entry address.                            |
|                    | <2> Loads halfword data pointed by address generated in <1>.                                                                                                                                                        |
|                    | <3> Sign-extends the loaded halfword data to word length, and adds the table entry address after logically shifts it left by 1 bit (next address following SWITCH instruction) to generate a 32-bit target address. |
|                    | <4> Then jumps to the target address generated in <3>.                                                                                                                                                              |

SAT –

| SXB                | Siç                                                  | gn extend byte |
|--------------------|------------------------------------------------------|----------------|
|                    | Sig                                                  | n Extend Byte  |
| Instruction format | SXB reg1                                             |                |
| Operation          | GR [reg1] $\leftarrow$ sign-extend (GR [reg1] (7:0)) |                |
| Format             | Format I                                             |                |
| Opcode             | 15 0<br>0000000101RRRRR                              |                |
| Flag               | CY –<br>OV –<br>S –<br>Z –                           |                |

**Explanation** Sign-extends the lowest byte of general-purpose register reg1 to word length.

CY

٥v

s

Ζ

SAT

\_

\_

\_

\_

\_

Flag

Explanation

| SXH                |                                                       | Sign extend halfword |
|--------------------|-------------------------------------------------------|----------------------|
|                    |                                                       | Sign Extend Halfword |
|                    |                                                       |                      |
| Instruction format | SXH reg1                                              |                      |
|                    |                                                       |                      |
| Operation          | $GR [reg1] \leftarrow sign-extend (GR [reg1] (15:0))$ |                      |
|                    |                                                       |                      |
| Format             | Format I                                              |                      |
|                    |                                                       |                      |
| Opcode             | 15 0                                                  |                      |
|                    | 0000000111RRRRR                                       |                      |

Sign-extends the lower halfword of general-purpose register reg1 to word length.

| User's Manual I | J15943EJ2V0UM |
|-----------------|---------------|
|-----------------|---------------|

# <Special instruction>

|                    |                                                                                                                                                                                                                                                                                                                                                                                                                                  | Trap   |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|
| TRAP               |                                                                                                                                                                                                                                                                                                                                                                                                                                  |        |
|                    |                                                                                                                                                                                                                                                                                                                                                                                                                                  | Trap   |
|                    |                                                                                                                                                                                                                                                                                                                                                                                                                                  | Παρ    |
| Instruction format | TRAP vector                                                                                                                                                                                                                                                                                                                                                                                                                      |        |
| Operation          | $\begin{split} EIPC &\leftarrow PC + 4 \text{ (restore PC)} \\ EIPSW &\leftarrow PSW \\ ECR.EICC &\leftarrow interrupt \ code \\ PSW.EP &\leftarrow 1 \\ PSW.ID &\leftarrow 1 \\ PC &\leftarrow 00000040H \text{ (vector = 00H to 0FH)} \\ & 00000050H \text{ (vector = 10H to 1FH)} \end{split}$                                                                                                                                |        |
| Format             | Format X                                                                                                                                                                                                                                                                                                                                                                                                                         |        |
| Opcode             | 15     0     31     16       0000011111111111111111111111111111111                                                                                                                                                                                                                                                                                                                                                               |        |
| Flag               | CY       -         OV       -         S       -         Z       -         SAT       -                                                                                                                                                                                                                                                                                                                                            |        |
| Explanation        | Saves the restore PC and PSW to EIPC and EIPSW, respectively; sets the exception (EICC of ECR) and the flags of the PSW (sets EP and ID flags to 1); jumps to the har address corresponding to the trap vector (00H to 1FH) specified by vector, and sexception processing.<br>The flags of PSW other than EP and ID flags are not affected.<br>The restore PC is the address of the instruction following the TRAP instruction. | andler |

| TST | Test |
|-----|------|
|     | Test |
|     |      |

| Instruction format | TST reg1, reg2                                                                                                                                                                                                                           |  |  |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Operation          | result $\leftarrow$ GR [reg2] AND GR [reg1]                                                                                                                                                                                              |  |  |
| Format             | Format I                                                                                                                                                                                                                                 |  |  |
| Opcode             | 15 0<br>rrrr001011RRRRR                                                                                                                                                                                                                  |  |  |
| Flag               | CY-OV0S1 if the operation result is negative; otherwise, 0.Z1 if the operation result is 0; otherwise, 0.SAT-                                                                                                                            |  |  |
| Explanation        | ANDs the word data of general-purpose register reg2 with the word data of general-purpose register reg1. The result is not stored, and only the flags are changed. The data of general-purpose registers reg1 and reg2 are not affected. |  |  |

# <Bit manipulation instruction>

| TST1               | Test bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | Test Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Instruction format | <ul><li>(1) TST1 bit#3, disp16 [reg1]</li><li>(2) TST1 reg2, [reg1]</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Operation          | <ol> <li>adr ← GR [reg1] + sign-extend (disp16)</li> <li>Z flag ← Not (Load-memory-bit (adr, bit#3))</li> <li>adr ← GR [reg1]</li> <li>Z flag ← Not (Load-memory-bit (adr, reg2))</li> </ol>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Format             | <ul><li>(1) Format VIII</li><li>(2) Format IX</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Opcode             | 15     0     31     16       (1)     11bbb111110RRRRR     dddddddddddddddddddddddd       15     0     31     16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                    | (2) rrrr111111RRRR 000000011100110                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Flag               | CY-OV-S-Z1 if bit specified by operands = 0, 0 if bit specified by operands = 1SAT-                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Explanation        | <ol> <li>Adds the data of general-purpose 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 bit number, at the byte data location referenced by the generated address. If the specified bit is 0, the Z flag of PSW is set to 1; if the bit is 1, the Z flag is cleared to 0. The byte data, including the specified bit, is not affected.</li> <li>Reads the data of general-purpose register reg1 to generate a 32-bit address. Performs the test on the bit, specified by the lower 3-bits of reg2, at the byte data location referenced by the generate a feature of power in the test on the bit, specified by the lower 3-bits of reg2, at the byte data location</li> </ol> |
|                    | referenced by the generated address. If the specified bit is 0, the Z flag of PSW is set to 1; if the bit is 1, the Z flag is cleared to 0. The byte data, including the specified bit, is not affected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| XOR | Exclusive OR |
|-----|--------------|
|     | Exclusive Or |
|     |              |

| Instruction format | XOR reg1, reg2                                                                                                                                                                                                                                |  |  |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Operation          | GR [reg2] ← GR [reg2] XOR GR [reg1]                                                                                                                                                                                                           |  |  |
| Format             | Format I                                                                                                                                                                                                                                      |  |  |
| Opcode             | 15 0<br>rrrrr001001RRRRR                                                                                                                                                                                                                      |  |  |
| Flag               | CY-OV0S1 if the operation result is negative; otherwise, 0.Z1 if the operation result is 0; otherwise, 0.SAT-                                                                                                                                 |  |  |
| Explanation        | Exclusively ORs the word data of general-purpose register reg2 with the word data of general-<br>purpose register reg1, and stores the result to general-purpose register reg2. The data of<br>general-purpose register reg1 is not affected. |  |  |

| XORI               |                                                                                                               | Exclusive OR immediate (16-bit) |
|--------------------|---------------------------------------------------------------------------------------------------------------|---------------------------------|
|                    |                                                                                                               | Exclusive Or Immediate          |
| Instruction format | XORI imm16, reg1, reg2                                                                                        |                                 |
| Operation          | GR [reg2] $\leftarrow$ GR [reg1] XOR zero-extend (imm16)                                                      |                                 |
| Format             | Format VI                                                                                                     |                                 |
| Opcode             | 15     0     31     16       rrrrr110101RRRR     iiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiii                         |                                 |
| Flag               | CY-OV0S1 if the operation result is negative; otherwise, 0.Z1 if the operation result is 0; otherwise, 0.SAT- |                                 |

ExplanationExclusively ORs the word data of general-purpose register reg1 with a 16-bit immediate data,<br/>zero-extended to word length, and stores the result to general-purpose register reg2. The data<br/>of general-purpose register reg1 is not affected.

| ZXB | Zero extend byte |
|-----|------------------|
|     | Zero Extend Byte |
|     |                  |

| Instruction format | ZXB reg1                                                                      |
|--------------------|-------------------------------------------------------------------------------|
| Operation          | $GR [reg1] \leftarrow zero-extend (GR [reg1] (7:0))$                          |
| Format             | Format I                                                                      |
| Opcode             | 15 0<br>0000000100RRRR                                                        |
| Flag               | CY –<br>OV –<br>S –<br>Z –<br>SAT –                                           |
| Explanation        | Zero-extends the lowest byte of general-purpose register reg1 to word length. |

| ZXH                |                                                                                       | Zero extend halfword |
|--------------------|---------------------------------------------------------------------------------------|----------------------|
|                    |                                                                                       | Zero Extend Halfword |
| Instruction format | ZXH reg1                                                                              |                      |
| Operation          | GR [reg1] $\leftarrow$ zero-extend (GR [reg1] (15:0))                                 |                      |
| Format             | Format I                                                                              |                      |
| Opcode             | 15 0<br>0000000110RRRR                                                                |                      |
| Flag               | CY       -         OV       -         S       -         Z       -         SAT       - |                      |

**Explanation** Zero-extends the lower halfword of general-purpose register reg1 to word length.

# 5.4 Number of Instruction Execution Clock Cycles

A list of the number of instruction execution clocks when the internal ROM or internal RAM is used is shown below. The number of instruction execution clock cycles differ depending on the combination of instructions. For details, see **CHAPTER 8 PIPELINE**.

| Type of      | Mnemonic | Operand                | Byte | Numbe | er of Execution | on Clocks |
|--------------|----------|------------------------|------|-------|-----------------|-----------|
| Instruction  |          |                        |      | i     | r               | I         |
| Load         | LD.B     | disp16 [reg1] , reg2   | 4    | 1     | 1               | Note 1    |
| instructions | LD.H     | disp16 [reg1] , reg2   | 4    | 1     | 1               | Note 1    |
|              | LD.W     | disp16 [reg1] , reg2   | 4    | 1     | 1               | Note 1    |
|              | LD.BU    | disp16 [reg1] , reg2   | 4    | 1     | 1               | Note 1    |
|              | LD.HU    | disp16 [reg1] , reg2   | 4    | 1     | 1               | Note 1    |
|              | SLD.B    | disp7 [ep], reg2       | 2    | 1     | 1               | Note 2    |
|              | SLD.BU   | disp4 [ep] , reg2      | 2    | 1     | 1               | Note 2    |
|              | SLD.H    | disp8 [ep] , reg2      | 2    | 1     | 1               | Note 2    |
|              | SLD.HU   | disp5 [ep] , reg2      | 2    | 1     | 1               | Note 2    |
|              | SLD.W    | disp8 [ep] , reg2      | 2    | 1     | 1               | Note 2    |
| Store        | ST.B     | reg2, disp16 [reg1]    | 4    | 1     | 1               | 1         |
| instructions | ST.H     | reg2, disp16 [reg1]    | 4    | 1     | 1               | 1         |
|              | ST.W     | reg2, disp16 [reg1]    | 4    | 1     | 1               | 1         |
|              | SST.B    | reg2, disp7 [ep]       | 2    | 1     | 1               | 1         |
|              | SST.H    | reg2, disp8 [ep]       | 2    | 1     | 1               | 1         |
|              | SST.W    | reg2, disp8 [ep]       | 2    | 1     | 1               | 1         |
| Multiply     | MUL      | reg1, reg2, reg3       | 4    | 1     | 4               | 5         |
| instructions | MUL      | imm9, reg2, reg3       | 4    | 1     | 4               | 5         |
|              | MULH     | reg1, reg2             | 2    | 1     | 1               | 2         |
|              | MULH     | imm5, reg2             | 2    | 1     | 1               | 2         |
|              | MULHI    | imm16, reg1, reg2      | 4    | 1     | 1               | 2         |
|              | MULU     | reg1, reg2, reg3       | 4    | 1     | 4               | 5         |
|              | MULU     | imm9, reg2, reg3       | 4    | 1     | 4               | 5         |
| Arithmetic   | ADD      | reg1, reg2             | 2    | 1     | 1               | 1         |
| operation    | ADD      | imm5, reg2             | 2    | 1     | 1               | 1         |
| instructions | ADDI     | imm16, reg1, reg2      | 4    | 1     | 1               | 1         |
|              | CMOV     | cccc, reg1, reg2, reg3 | 4    | 1     | 1               | 1         |
|              | CMOV     | cccc, imm5, reg2, reg3 | 4    | 1     | 1               | 1         |
|              | CMP      | reg1, reg2             | 2    | 1     | 1               | 1         |
|              | CMP      | imm5, reg2             | 2    | 1     | 1               | 1         |
|              | DIV      | reg1, reg2, reg3       | 4    | 35    | 35              | 35        |
|              | DIVH     | reg1, reg2             | 2    | 35    | 35              | 35        |
|              | DIVH     | reg1, reg2, reg3       | 4    | 35    | 35              | 35        |
|              | DIVHU    | reg1, reg2, reg3       | 4    | 34    | 34              | 34        |

Table 5-6. List of Number of Instruction Execution Clock Cycles (1/3)

| Type of      | Mnemonic | Operand                                 | Byte | Number              | of Executio         | n Clocks            |
|--------------|----------|-----------------------------------------|------|---------------------|---------------------|---------------------|
| Instruction  |          |                                         |      | i                   | r                   | I                   |
| Arithmetic   | DIVU     | reg1, reg2, reg3                        | 4    | 34                  | 34                  | 34                  |
| operation    | MOV      | reg1, reg2                              | 2    | 1                   | 1                   | 1                   |
| instructions | MOV      | imm5, reg2                              | 2    | 1                   | 1                   | 1                   |
|              | MOV      | imm32, reg1                             | 6    | 2                   | 2                   | 2                   |
|              | MOVEA    | imm16, reg1, reg2                       | 4    | 1                   | 1                   | 1                   |
|              | MOVHI    | imm16, reg1, reg2                       | 4    | 1                   | 1                   | 1                   |
|              | SASF     | cccc, reg2                              | 4    | 1                   | 1                   | 1                   |
|              | SETF     | cccc, reg2                              | 4    | 1                   | 1                   | 1                   |
|              | SUB      | reg1, reg2                              | 2    | 1                   | 1                   | 1                   |
|              | SUBR     | reg1, reg2                              | 2    | 1                   | 1                   | 1                   |
| Saturated    | SATADD   | reg1, reg2                              | 2    | 1                   | 1                   | 1                   |
| operation    | SATADD   | imm5, reg2                              | 2    | 1                   | 1                   | 1                   |
| instructions | SATSUB   | reg1, reg2                              | 2    | 1                   | 1                   | 1                   |
|              | SATSUBI  | imm16, reg1, reg2                       | 4    | 1                   | 1                   | 1                   |
|              | SATSUBR  | reg1, reg2                              | 2    | 1                   | 1                   | 1                   |
| Logical      | AND      | reg1, reg2                              | 2    | 1                   | 1                   | 1                   |
| operation    | ANDI     | imm16, reg1, reg2                       | 4    | 1                   | 1                   | 1                   |
| instructions | BSH      | reg2, reg3                              | 4    | 1                   | 1                   | 1                   |
|              | BSW      | reg2, reg3                              | 4    | 1                   | 1                   | 1                   |
|              | HSW      | reg2, reg3                              | 4    | 1                   | 1                   | 1                   |
|              | NOT      | reg1, reg2                              | 2    | 1                   | 1                   | 1                   |
|              | OR       | reg1, reg2                              | 2    | 1                   | 1                   | 1                   |
|              | ORI      | imm16, reg1, reg2                       | 4    | 1                   | 1                   | 1                   |
|              | SAR      | reg1, reg2                              | 4    | 1                   | 1                   | 1                   |
|              | SAR      | imm5, reg2                              | 2    | 1                   | 1                   | 1                   |
|              | SHL      | reg1, reg2                              | 4    | 1                   | 1                   | 1                   |
|              | SHL      | imm5, reg2                              | 2    | 1                   | 1                   | 1                   |
|              | SHR      | reg1, reg2                              | 4    | 1                   | 1                   | 1                   |
|              | SHR      | imm5, reg2                              | 2    | 1                   | 1                   | 1                   |
|              | SXB      | reg1                                    | 2    | 1                   | 1                   | 1                   |
|              | SXH      | reg1                                    | 2    | 1                   | 1                   | 1                   |
|              | TST      | reg1, reg2                              | 2    | 1                   | 1                   | 1                   |
|              | XOR      | reg1, reg2                              | 2    | 1                   | 1                   | 1                   |
|              | XORI     | imm16, reg1, reg2                       | 4    | 1                   | 1                   | 1                   |
|              | ZXB      | reg1                                    | 2    | 1                   | 1                   | 1                   |
|              | ZXH      | reg1                                    | 2    | 1                   | 1                   | 1                   |
| Branch       | Bcond    | disp9 (When condition is satisfied)     | 2    | 2 <sup>Note 3</sup> | 2 <sup>Note 3</sup> | 2 <sup>Note 3</sup> |
| instructions |          | disp9 (When condition is not satisfied) | 2    | 1                   | 1                   | 1                   |

 Table 5-6. List of Number of Instruction Execution Clock Cycles (2/3)

| Type of           | Mnemonic  | Operand              | Byte | Number                | of Executio           | n Clocks              |
|-------------------|-----------|----------------------|------|-----------------------|-----------------------|-----------------------|
| Instruction       |           |                      |      | i                     | r                     | I                     |
| Branch            | JARL      | disp22, reg2         | 4    | 2                     | 2                     | 2                     |
| instructions      | JMP       | [reg1]               | 2    | 3                     | 3                     | 3                     |
|                   | JR        | disp22               | 4    | 2                     | 2                     | 2                     |
| Bit manipulation  | CLR1      | bit#3, disp16 [reg1] | 4    | 3 <sup>Note 4</sup>   | 3 <sup>Note 4</sup>   | 3 <sup>Note 4</sup>   |
| instructions      | CLR1      | reg2, [reg1]         | 4    | 3 <sup>Note 4</sup>   | 3 <sup>Note 4</sup>   | 3 <sup>Note 4</sup>   |
|                   | NOT1      | bit#3, disp16 [reg1] | 4    | 3 <sup>Note 4</sup>   | 3 <sup>Note 4</sup>   | 3 <sup>Note 4</sup>   |
|                   | NOT1      | reg2, [reg1]         | 4    | 3 <sup>Note 4</sup>   | 3 <sup>Note 4</sup>   | 3 <sup>Note 4</sup>   |
|                   | SET1      | bit#3, disp16 [reg1] | 4    | 3 <sup>Note 4</sup>   | 3 <sup>Note 4</sup>   | 3 <sup>Note 4</sup>   |
|                   | SET1      | reg2, [reg1]         | 4    | 3 <sup>Note 4</sup>   | 3 <sup>Note 4</sup>   | 3 <sup>Note 4</sup>   |
|                   | TST1      | bit#3, disp16 [reg1] | 4    | 3 <sup>Note 4</sup>   | 3 <sup>Note 4</sup>   | 3 <sup>Note 4</sup>   |
|                   | TST1      | reg2, [reg1]         | 4    | 3 <sup>Note 4</sup>   | 3 <sup>Note 4</sup>   | 3 <sup>Note 4</sup>   |
| Special           | CALLT     | imm6                 | 2    | 4                     | 4                     | 4                     |
| instructions      | CTRET     | -                    | 4    | 3                     | 3                     | 3                     |
|                   | DI        | -                    | 4    | 1                     | 1                     | 1                     |
|                   | DISPOSE   | imm5, list12         | 4    | n+1 <sup>Note 5</sup> | n+1 <sup>Note 5</sup> | n+1 <sup>Note 5</sup> |
|                   | DISPOSE   | imm5, list12, [reg1] | 4    | n+3 <sup>Note 5</sup> | n+3 <sup>Note 5</sup> | n+3 <sup>Note 5</sup> |
|                   | EI        | -                    | 4    | 1                     | 1                     | 1                     |
|                   | HALT      | -                    | 4    | 1                     | 1                     | 1                     |
|                   | LDSR      | reg2, regID          | 4    | 1                     | 1                     | 1                     |
|                   | NOP       | -                    | 2    | 1                     | 1                     | 1                     |
|                   | PREPARE   | list12, imm5         | 4    | n+1 <sup>Note 5</sup> | n+1 <sup>Note 5</sup> | n+1 <sup>Note 5</sup> |
|                   | PREPARE   | list12, imm5, sp     | 4    | n+2 <sup>Note 5</sup> | n+2 <sup>Note 5</sup> | n+2 <sup>Note 5</sup> |
|                   | PREPARE   | list12, imm5, imm16  | 6    | n+2 <sup>Note 5</sup> | n+2 <sup>Note 5</sup> | n+2 <sup>Note 5</sup> |
|                   | PREPARE   | list12, imm5, imm32  | 8    | n+3 <sup>Note 5</sup> | n+3 <sup>Note 5</sup> | n+3 <sup>Note 5</sup> |
|                   | RETI      | -                    | 4    | 3                     | 3                     | 3                     |
|                   | STSR      | regID, reg2          | 4    | 1                     | 1                     | 1                     |
|                   | SWITCH    | reg1                 | 2    | 5                     | 5                     | 5                     |
|                   | TRAP      | vector               | 4    | 3                     | 3                     | 3                     |
| Debug function    | DBRET     | -                    | 4    | 3                     | 3                     | 3                     |
| instructions      | DBTRAP    | -                    | 2    | 3                     | 3                     | 3                     |
| Undefined instruc | tion code | •                    | 4    | 3                     | 3                     | 3                     |

| Table 5-6. List of Number | of Instruction Execution | Clock Cycles (3/3) |
|---------------------------|--------------------------|--------------------|
|                           |                          |                    |

Notes 1. Depends on the number of wait states (2 if no wait states).

2. Depends on the number of wait states (1 if no wait states).

- **3.** 3 if there is an instruction rewriting the PSW contents immediately before.
- 4. In case of no wait states (3 + number of read access wait states).
- n is the total number of cycles to load registers in list12 (Depends on the number of wait states, n is the number of registers in list12 if no wait states. The operation when n = 0 is the same as when n = 1).

### Remarks 1. Operand convention

| Symbol | Meaning                                                                                                       |
|--------|---------------------------------------------------------------------------------------------------------------|
| reg1   | General-purpose register (used as source register)                                                            |
| reg2   | General-purpose register (mainly used as destination register. Some are also used as source registers.)       |
| reg3   | General-purpose register (mainly used as remainder of division results or higher 32 bits of multiply results) |
| bit#3  | 3-bit data for bit number specification                                                                       |
| imm×   | ×-bit immediate data                                                                                          |
| disp×  | ×-bit displacement data                                                                                       |
| regID  | System register number                                                                                        |
| vector | 5-bit data for trap vector (00H to 1FH) specification                                                         |
| сссс   | 4-bit data condition code specification                                                                       |
| sp     | Stack pointer (r3)                                                                                            |
| ер     | Element pointer (r30)                                                                                         |
| list×  | List of registers (× is a maximum number of registers)                                                        |

#### 2. Execution clock convention

| Symbol | Meaning                                                                                                                           |
|--------|-----------------------------------------------------------------------------------------------------------------------------------|
| i      | When other instruction is executed immediately after executing an instruction (issue)                                             |
| r      | When the same instruction is repeatedly executed immediately after the instruction has been executed (repeat)                     |
| 1      | When a subsequent instruction uses the result of execution of the preceding instruction immediately after its execution (latency) |

#### **CHAPTER 6 INTERRUPTS AND EXCEPTIONS**

Interrupts are events that occur independently of the program execution and are divided into two types: maskable interrupts and non-maskable interrupts (NMI). In contrast, exceptions are events whose occurrence is dependent on the program execution and are divided into three types: software exception, exception trap, and debug trap.

When an interrupt or exception occurs, control is transferred to a handler whose address is determined by the source of the interrupt or exception. The source of the interrupt/exception is specified by the exception code that is stored in the exception cause register (ECR). Each handler analyzes the ECR register and performs appropriate interrupt servicing or exception processing. The restore PC and restore PSW are written to the status saving registers (EIPC, EIPSW or FEPC, FEPSW).

To restore execution from interrupt or software exception processing, use the RETI instruction. To restore execution from exception trap or debug trap, use the DBRET instruction. Read the restore PC and restore PSW from the status saving register, and transfer control to the restore PC.

| li                   | nterrupt/Exception Sourc    | e                            | Classification | Exception | Handler   | Restore PC                    |
|----------------------|-----------------------------|------------------------------|----------------|-----------|-----------|-------------------------------|
| Ν                    | lame                        | Trigger                      |                | Code      | Address   |                               |
| Non-maskable interr  | upt (NMI) <sup>Note 1</sup> | NMI0 input                   | Interrupt      | 0010H     | 00000010H | next PC <sup>Note 2</sup>     |
|                      |                             | NMI1 input                   | Interrupt      | 0020H     | 0000020H  | next PC <sup>Notes 2, 3</sup> |
|                      |                             | NMI2 input <sup>Note 4</sup> | Interrupt      | 0030H     | 00000030H | next PC <sup>Notes 2, 3</sup> |
| Maskable interrupt   | able interrupt              |                              | Interrupt      | Note 5    | Note 6    | next PC <sup>Note 2</sup>     |
| Software exception   | TRAP0n (n = 0 to FH)        | TRAP instruction             | Exception      | 004nH     | 00000040H | next PC                       |
|                      | TRAP1n (n = 0 to FH)        | TRAP instruction             | Exception      | 005nH     | 00000050H | next PC                       |
| Exception trap (ILGC | DP)                         | Illegal instruction code     | Exception      | 0060H     | 00000060H | next PC <sup>Note 7</sup>     |
| Debug trap           |                             | DBTRAP<br>instruction        | Exception      | 0060H     | 00000060H | next PC                       |

#### Table 6-1. Interrupt/Exception Codes

**Notes 1.** The trigger of the non-maskable interrupt incorporated differs depending on the product.

- Except when an interrupt is acknowledged during execution of the one of the instructions listed below (if an interrupt is acknowledged during instruction execution, execution is stopped, and then resumed after the completion of interrupt servicing. In this case, the address of the stopped instruction is the restored PC.).
  - Load instructions (SLD.B, SLD.BU, SLD.H, SLD.HU, SLD.W), divide instructions (DIV, DIVH, DIVU, DIVHU)
  - PREPARE, DISPOSE instruction (only if an interrupt is generated before the stack pointer is updated)
- 3. The PC cannot be restored by the RETI instruction. Perform a system reset after interrupt servicing.
- 4. Acknowledged even if the NP flag of PSW is set to 1.
- 5. Differs depending on the type of the interrupts.
- 6. Higher 16 bits are 0000H and lower 16 bits are the same value as the exception code.
- 7. The execution address of the illegal instruction is obtained by "Restore PC 4".
- **Remark** Restore PC: PC value saved to the EIPC or FEPC when interrupt/exception processing is started next PC: PC value that starts processing after interrupt/exception processing

#### 6.1 Interrupt Servicing

#### 6.1.1 Maskable interrupt

The maskable interrupt can be masked by the interrupt control register of the interrupt controller (INTC).

The INTC issues an interrupt request to the CPU, based on the acknowledged interrupt with the highest priority. If a maskable interrupt occurs due to interrupt request input (INT input), 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 halfword of ECR (EICC).
- (4) Sets ID flag of PSW to 1 and clears EP flag to 0.
- (5) Sets handler address for each interrupt to PC and transfers control.

The EIPC and EIPSW are used as the status saving registers. INT inputs are held pending in the interrupt controller (INTC) when one of the following two conditions occur: when the INT input is masked by its interrupt controller, or when an interrupt service routine is currently being executed (when the NP flag of the PSW is 1 or when the ID flag of the PSW is 1). Interrupts are enabled by clearing the mask condition or by setting the NP and ID flags of the PSW to 0 with the LDSR instruction, which will be enabling new maskable interrupt servicing by a pending INT input.

The EIPC and EIPSW registers must be saved by program to enable nesting of interrupts because there is only one set of EIPC and EIPSW is provided.

Maskable interrupt servicing format is shown below.





#### 6.1.2 Non-maskable interrupt

The non-maskable interrupt cannot be disabled by an instruction and therefore can always be acknowledged. The non-maskable interrupt is generated by the NMI input.

When the non-maskable interrupt is generated, the CPU 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 (0010H) to higher halfword of ECR (FECC).
- (4) Sets NP and ID flags of PSW to 1 and clears EP flag to 0.
- (5) Sets handler address for the non-maskable interrupt to PC and transfers control.

The FEPC and FEPSW are used as the status saving registers.

Non-maskable interrupts are held pending in the interrupt controller when another non-maskable interrupt is currently being executed (when the NP flag of the PSW is 1). Non-maskable interrupts are enabled by setting the NP flag of the PSW to 0 with the RETI and LDSR instructions, which will be enabling new non-maskable interrupt servicing by a pending non-maskable interrupt request.

In the case of products that incorporate an interrupt trigger for NMI2, only when NMI2 is generated during the interrupt servicing of NMI0 and NMI1, NMI2 servicing is executed regardless of the value of NP flag.

Non-maskable interrupt servicing format is shown below.



Figure 6-2. Non-Maskable Interrupt Servicing Format

#### 6.2 Exception Processing

#### 6.2.1 Software exception

A software exception is generated when the TRAP instruction is executed and is always acknowledged.

- 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 source).
- (4) Sets EP and ID flags of PSW to 1.
- (5) Sets handler address (00000040H or 00000050H) for software exception to PC and transfers control.

Software exception processing format is shown below.



#### Figure 6-3. Software Exception Processing Format

#### 6.2.2 Exception trap

An exception trap is an exception requested when an instruction is illegally executed. The illegal opcode trap (ILGOP) is the exception trap.

An illegal opcode instruction has an instruction code with an opcode (bits 10 through 5) of 111111B and a subopcode (bits 26 through 23) of 0111B through 1111B and a sub-opcode (bit 16) of 0B. When this kind of an illegal opcode instruction is executed, an exception trap occurs.



| × | ~ | × | × | 1 | 1 | 1 | . 1 | . 1 | . 1 |    |   | ~ | ~ |   | × | ~ | × | × | 0 | 1<br>to | 1      | 1 | × | × | ~ | · · ·  | ~ | × | 0 |
|---|---|---|---|---|---|---|-----|-----|-----|----|---|---|---|---|---|---|---|---|---|---------|--------|---|---|---|---|--------|---|---|---|
| ~ | ~ |   | ^ |   | ' | ' |     |     | '   | l^ | ^ | ~ | ^ | ^ | ~ | ~ | ~ |   | 1 | 1       | ,<br>1 | 1 |   | ^ |   | $\sim$ | ~ | ^ |   |

If an exception trap occurs, the CPU performs the following steps, and transfers control to the handler routine.

- (1) Saves restore PC to DBPC.
- (2) Saves current PSW to DBPSW.
- (3) Sets NP, EP, and ID flags of PSW to 1.
- (4) Sets handler address (00000060H) for exception trap to PC and transfers control.

Exception trap processing format is shown below.





# Caution The operation when executing the instruction not defined as an instruction or illegal instruction is not guaranteed.

**Remark** The execution address of the illegal instruction is obtained by "Restore PC - 4".

#### 6.2.3 Debug trap

A debug trap is generated when the DBTRAP instruction is executed and is always acknowledged. If a debug trap occurs, the CPU performs the following steps.

- (1) Saves restore PC to DBPC.
- (2) Saves current PSW to DBPSW.
- (3) Sets NP, EP, and ID flags of PSW to 1.
- (4) Sets handler address (0000060H) for debug trap to PC and transfers control.

Debug trap processing format is shown below.



#### Figure 6-6. Debug Trap Processing Format

#### 6.3 Restoring from Interrupt/Exception Processing

#### 6.3.1 Restoring from interrupt and software exception

All restoration from interrupt servicing and software exception is executed by the RETI instruction.

With the RETI instruction, the CPU performs the following steps, and transfers control to the address of the restore PC.

- (1) If the EP flag of the PSW is 0 and the NP flag 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 each interrupt servicing, the NP and EP flags 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:

- To restore from non-maskable interrupt servicing<sup>Note</sup>: NP flag of PSW = 1, EP flag = 0
- To restore from maskable interrupt servicing: NP flag of PSW = 0, EP flag = 0
- To restore from exception processing: EP flag of PSW = 1
- **Note** In the case of the products that incorporate interrupt trigger for NMI1 and NMI2, NMI1 and NMI2 cannot be restored by the RETI instruction. Execute the system reset after the interrupt servicing. NMI2 can be acknowledged even if the NP flag of PSW is set to 1.

Restoration from interrupt/exception processing format is shown below.





#### 6.3.2 Restoring from exception trap and debug trap

Restoration from exception trap and debug trap is executed by the DBRET instruction.

With the DBRET instruction, the CPU performs the following steps, and transfers control to the address of the restore PC.

- (1) The restore PC and PSW are read from the DBPC and DBPSW.
- (2) Control is transferred to the address of the restored PC and PSW.

Restoration from exception trap/debug trap processing format is shown below.





# CHAPTER 7 RESET

### 7.1 Register Status After Reset

When a low-level signal is input to the reset pin, the system is reset, and program registers and system registers are set in the status shown in Table 7-1. When the reset signal goes high, the reset status is cleared, and program execution begins. If necessary, initialize the contents of each register by program control.

|                   | Register                                            | Status After Reset (Initial Value) |
|-------------------|-----------------------------------------------------|------------------------------------|
| Program registers | General-purpose register (r0)                       | 00000000H (Fixed)                  |
|                   | General-purpose register (r1 to r31)                | Undefined                          |
|                   | Program counter (PC)                                | 0000000H                           |
| System registers  | Interrupt status saving register (EIPC)             | 0xxxxxxH                           |
|                   | Interrupt status saving register (EIPSW)            | 00000xxxH                          |
|                   | NMI status saving register (FEPC)                   | 0xxxxxxH                           |
|                   | NMI status saving register (FEPSW)                  | 00000xxxH                          |
|                   | Exception cause register (ECR)                      | 0000000H                           |
|                   | Program status word (PSW)                           | 0000020H                           |
|                   | CALLT caller status saving register (CTPC)          | 0xxxxxxH                           |
|                   | CALLT caller status saving register (CTPSW)         | 00000xxxH                          |
|                   | Exception/debug trap status saving register (DBPC)  | 0xxxxxxH                           |
|                   | Exception/debug trap status saving register (DBPSW) | 00000xxxH                          |
|                   | CALLT base pointer (CTBP)                           | 0xxxxxxH                           |

#### Table 7-1. Register Status After Reset

Remark x: Undefined

#### 7.2 Starting Up

The CPU begins program execution from address 00000000H after it has been reset.

After reset, no immediate interrupt requests are acknowledged. To enable interrupts by program, clear the ID flag of the PSW to 0.

## **CHAPTER 8 PIPELINE**

The V850ES CPU is based on the RISC architecture and executes almost all the instructions in one clock cycle under control of a 5-stage pipeline. The instruction execution sequence usually consists of five stages including fetch (IF) to write back (WB) 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 9 standard instructions are executed in succession.

| Internal system clock                  |     |         |          |        |          |          |          |         |          |          |          |                              |      |
|----------------------------------------|-----|---------|----------|--------|----------|----------|----------|---------|----------|----------|----------|------------------------------|------|
| Processing CPU performs simultaneously | <1> | <2>     | <3>      | <4>    | <5>      | <6>      | <7>      | <8>     | <9>      | <10>     | <11>     | <12>                         | <13> |
| 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       |          |          |                              |      |
| Instruction 6                          |     |         |          |        |          | IF       | ID       | EX      | MEM      | WB       |          |                              |      |
| Instruction 7                          |     |         |          |        |          |          | IF       | ID      | EX       | МЕМ      | WB       |                              |      |
| Instruction 8                          |     |         |          |        |          |          |          | IF      | ID       | EX       | MEM      | WB                           |      |
| Instruction 9                          |     |         |          |        |          |          |          |         | IF       | ID       | EX       | MEM                          | WB   |
|                                        |     |         |          |        | instruc- | instruc- | instruc- |         | instruc- | instruc- | instruc- | End of<br>instruc-<br>tion 8 |      |
|                                        |     |         |          |        |          | Ev       | ocutos   | instruc |          | (on) 1 ( |          |                              |      |
| IF (instruction fetch):                | Ins | tructio | on is fe | etched | and f    |          |          | is incr |          |          |          | yoic                         |      |
| ID (instruction decode):               |     |         |          |        |          |          |          |         |          |          | l regis  | ter is r                     | ead. |
| EX (execution of ALU, mul              |     |         |          |        |          |          |          | ed inst |          |          | •        |                              |      |

#### Figure 8-1. Example of Executing Nine Standard Instructions

<1> through <13> in the figure above indicate the states of the CPU. In each state, write back (WB) of instruction n, memory access (MEM) of instruction n+1, execution (EX) of instruction n+2, decoding (ID) of instruction n+3, and fetching (IF) of instruction n+4 are simultaneously performed. It takes five clock cycles to process a standard instruction, including IF stage to WB stage. Because five instructions can be processed at the same time, however, a standard instruction can be executed in 1 clock on the average.

## 8.1 Features

The V850ES CPU, by optimizing the pipeline, improves the CPI (Cycle per instruction) rate over the previous V850 CPU.

The pipeline configuration of the V850ES CPU is shown in Figure 8-2.

Figure 8-2. Pipeline Configuration



## 8.1.1 Non-blocking load/store

As the pipeline does not stop during external memory access, efficient processing is possible.

For example, Figure 8-3 shows a comparison of pipeline operations between the V850 CPU and the V850ES CPU when an ADD instruction is executed after the execution of a load instruction for external memory.





## (1) V850 CPU

The EX stage of the ADD instruction is usually executed in 1 clock. However, a wait time is generated in the EX stage of the ADD instruction during execution of the MEM stage of the previous load instruction. This is because the same stage of the 5 instructions on the pipeline cannot be executed in the same internal clock interval. This also causes a wait time to be generated in the ID stage of the next instruction after the ADD instruction.

#### (2) V850ES CPU

An asynchronous WB pipeline for the instructions that are necessary for the MEM stage is provided in addition to the master pipeline. The MEM stage of the load instruction is therefore processed on this asynchronous WB pipeline. Because the ADD instruction is processed on the master pipeline, a wait time is not generated, making it possible to execute instructions efficiently as shown in Figure 8-3.

### 8.1.2 2-clock branch

When executing a branch instruction, the branch destination is decided in the ID stage.

In the case of the conventional V850 CPU, the branch destination of when the branch instruction is executed was decided after execution of the EX stage, but in the case of the V850ES CPU, due to the addition of a address calculation stage for branch/SLD instruction, the branch destination is decided in the ID stage. Therefore, it is possible to fetch the branch destination instruction 1 clock faster than in the conventional V850 CPU.

Figure 8-4 shows a comparison between the V850 CPU and the V850ES CPU of pipeline operations with branch instructions.



Figure 8-4. Pipeline Operations with Branch Instructions

### 8.1.3 Efficient pipeline processing

Because the V850ES CPU has an ID stage for branch/SLD instructions in addition to the ID stage on the master pipeline, it is possible to perform efficient pipeline processing.

Figure 8-5 shows an example of a pipeline operation where the next branch instruction was fetched in the IF stage of the ADD instruction (Instruction fetch from the ROM directly connected to the dedicated bus is performed in 32-bit units. Both ADD instructions and branch instructions in Figure 8-5 use a 16-bit format instruction).



Figure 8-5. Parallel Execution of Branch Instructions

#### (1) V850 CPU

Although the instruction codes up to the next branch instruction are fetched in the IF stage of the ADD instruction, the ID stage of the ADD instruction and the ID stage of the branch instruction cannot execute together within the same clock. Therefore, it takes 5 clocks from the branch instruction fetch to the branch destination instruction fetch.

### (2) V850ES CPU

Because V850ES CPU has an ID stage for branch/SLD instructions in addition to the ID stage on the master pipeline, the parallel execution of the ID stage of the ADD instruction and the ID stage of the branch instruction within the same clock is possible. Therefore, it takes only 3 clocks from the branch instruction fetch start to the branch destination instruction completion.

Caution Be aware that the SLD and Bcond instructions are sometimes executed at the same time as other 16-bit format instructions. For example, if the SLD and NOP instructions are executed simultaneously, the NOP instruction may keep the delay time from being generated.

## 8.2 Pipeline Flow During Execution of Instructions

This section explains the pipeline flow during the execution of instructions.

In pipeline processing, the CPU is already processing the next instruction when the memory or I/O write cycle is generated. As a result, I/O manipulations and interrupt request masking will be reflected later than next instructions are issued (ID stage).

When an interrupt mask manipulation is performed, maskable interrupt acknowledgement is disabled from the instruction immediately after an instruction because the CPU detects access to the internal INTC (ID stage) and performs interrupt request mask processing.

#### 8.2.1 Load instructions

Caution Due to non-blocking control, there is no guarantee that the bus cycle is complete between the MEM stages. However, when accessing the peripheral I/O area, blocking control is effected, making it possible to wait for the end of the bus cycle at the MEM stage.

#### (1) LD instructions

[Instructions] LD.B, LD.BU, LD.H, LD.HU, LD.W

| [Pipeline] |                  | <1> | <2> | <3> | <4> | <5> | <6> |
|------------|------------------|-----|-----|-----|-----|-----|-----|
|            | LD instruction   | IF  | ID  | EX  | MEM | WB  |     |
|            | Next instruction |     | 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 LD instruction, data wait time occurs.

#### (2) SLD instructions

[Instructions] SLD.B, SLD.BU, SLD.H, SLD.HU, SLD.W

[Pipeline] <1> <2> <3> <4> <5> <6> SLD instruction IF ID MEM WB IF ID ΕX MEM WB Next instruction

[Description] The pipeline consists of 4 stages, IF, ID, MEM, and WB. If an instruction using the execution result is placed immediately after the SLD instruction, data wait time occurs.

### 8.2.2 Store instructions

Caution Due to non-blocking control, there is no guarantee that the bus cycle is complete between the MEM stages. However, when accessing the peripheral I/O area, blocking control is effected, making it possible to wait for the end of the bus cycle at the MEM stage.

[Instructions] ST.B, ST.H, ST.W, SST.B, SST.H, SST.W

|            |                   | <1> | <2> | <3> | <4> | <5> | <6> |
|------------|-------------------|-----|-----|-----|-----|-----|-----|
| [Pipeline] | Store instruction | IF  | ID  | EX  | MEM | WB  |     |
|            | Next 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 WB stage, because no data is written to registers.

### 8.2.3 Multiply instructions

#### (1) Halfword data multiply instruction

| [Instructions] MU | LH, MULHI |
|-------------------|-----------|
|-------------------|-----------|

[Pipeline] (a) 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  |

(b) 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  |

<sup>[</sup>Description] The pipeline consists of 5 stages, IF, ID, EX1, EX2, and WB. The EX stage takes 2 clocks because it is executed by a multiplier. EX1 and EX2 stages (different from the normal EX stage) can operate independently. Therefore, the number of clocks for instruction execution is always 1 clock, 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.

### (2) Word data multiply instructions

[Instructions] MUL, MULU

[Pipeline] (a) When the next three instructions are not multiply instructions

| <1> | <2> | <3>   | <4>       | <5>                                | <6>                                           | <7>                                                      | <8>                                                             |
|-----|-----|-------|-----------|------------------------------------|-----------------------------------------------|----------------------------------------------------------|-----------------------------------------------------------------|
| IF  | ID  | EX1   | EX1       | EX1                                | EX1                                           | EX2                                                      | WB                                                              |
|     | IF  | ID    | EX        | MEM                                | WB                                            |                                                          | _                                                               |
|     |     | IF    | ID        | EX                                 | MEM                                           | WB                                                       |                                                                 |
|     |     |       | IF        | ID                                 | EX                                            | MEM                                                      | WB                                                              |
|     |     | IF ID | IF ID EX1 | IF ID EX1 EX1<br>IF ID EX<br>IF ID | IF ID EX1 EX1 EX1<br>IF ID EX MEM<br>IF ID EX | IF ID EX1 EX1 EX1 EX1<br>IF ID EX MEM WB<br>IF ID EX MEM | IF ID EX1 EX1 EX1 EX1 EX2<br>IF ID EX MEM WB<br>IF ID EX MEM WB |

## (b) When the next instruction is a multiply instruction

|                        | <1> | <2> | <3> | <4> | <5> | <6> | <7> | <8> | <9> |
|------------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Multiply instruction 1 | IF  | ID  | EX1 | EX1 | EX1 | EX1 | EX2 | WB  |     |
| Multiply instruction 2 |     | IF  | _   | _   | _   | ID  | EX1 | EX2 | WB  |
| (halfword)             |     |     |     |     |     |     |     |     |     |

-: Idle inserted for wait

(c) When the instruction following the next two instructions is a multiply instruction

|                        | <1> | <2> | <3> | <4> | <5> | <6> | <7> | <8> | <9> |
|------------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Multiply instruction 1 | IF  | ID  | EX1 | EX1 | EX1 | EX1 | EX2 | WB  |     |
| Instruction 1          |     | IF  | ID  | EX  | MEM | WB  |     |     | _   |
| Instruction 2          |     |     | IF  | ID  | EX  | MEM | WB  |     |     |
| Multiply instruction 2 |     |     |     | IF  | _   | ID  | EX1 | EX2 | WB  |
| (halfword)             |     |     |     |     |     |     |     |     |     |

-: Idle inserted for wait

[Description] The pipeline consists of 8 stages, IF, ID, EX1 (4 stages), EX2, and WB. The EX stage takes 5 clocks because it is executed by a multiplier. EX1 and EX2 stages (different from the normal EX stage) can operate independently. Therefore, the number of clocks for instruction execution is always 4 clocks, 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.

#### 8.2.4 Arithmetic operation instructions

#### (1) Instructions other than divide/move word instructions

[Instructions] ADD, ADDI, CMOV, CMP, MOV, MOVEA, MOVHI, SASF, SETF, SUB, SUBR <6> <1> <2> <3> <4> <5> Arithmetic operation [Pipeline] חו FΧ DF WB instruction IF ID EX MEM WB Next instruction [Description] The pipeline consists of 5 stages, IF, ID, EX, DF, and WB. (2) Move word instruction [Instructions] MOV imm32 <3> <5> <7> <1> <2> <4> <6> Arithmetic operation IF EX2 [Pipeline] ID FX1 DF WB instruction IF ID ΕX MEM WB Next instruction -: Idle inserted for wait [Description] The pipeline consists of 6 stages, IF, ID, EX1, EX2 (normal EX stage), DF, and WB. (3) Divide instructions [Instructions] DIV, DIVH, DIVHU, DIVU [Pipeline] (a) DIV, DIVH instructions <1> <2> <3> <35> <36> <37> <38> <39> <40> <41> wв Divide instruction ID EX35 DE FX1 EXC FX33 FX34 WB Next instruction IF ID FΧ MEM IF ID ΕX MEM WB Next to next instruction -: Idle inserted for wait (b) DIVHU, DIVU instructions <1> <2> <3> <35> <36> <37> <38> <39> <40> <4> ID wв Divide instruction IF FX1 FX2 FX34 DF Next instruction IF חו МЕМ wв FX Next to next instruction IF ID ΕX MEM WB -: Idle inserted for wait [Description] The pipeline consists of 39 stages, IF, ID, EX1 to EX35 (normal EX stage), DF, and WB for DIV and DIVH instructions. The pipeline consists of 38 stages, IF, ID, EX1 to EX34 (normal EX stage), DF, and WB for DIVHU and DIVU instructions. [Remark] If an interrupt occurs while a division instruction is executed, execution of the instruction is

#### 8.2.5 Saturated operation instructions

| [Instructions] | SATADD, SATSUB, SATSUBI, SATSUBR   |     |     |     |     |     |     |  |  |
|----------------|------------------------------------|-----|-----|-----|-----|-----|-----|--|--|
|                |                                    | <1> | <2> | <3> | <4> | <5> | <6> |  |  |
| [Pipeline]     | Saturated operation<br>instruction | IF  | ID  | EX  | DF  | WB  |     |  |  |
|                | Next instruction                   |     | IF  | ID  | EX  | MEM | WB  |  |  |
|                |                                    |     |     |     |     |     |     |  |  |

CATADO CATOLIO CATOLIOL CATOLIOD

[Description] The pipeline consists of 5 stages, IF, ID, EX, DF, and WB.

## 8.2.6 Logical operation instructions

[Instructions] AND, ANDI, BSH, BSW, HSW, NOT, OR, ORI, SAR, SHL, SHR, SXB, SXH, TST, XOR, XORI, ZXB, ZXH

|            |                                  | <1> | <2> | <3> | <4> | <5> | <6> |
|------------|----------------------------------|-----|-----|-----|-----|-----|-----|
| [Pipeline] | Logical operation<br>instruction | IF  | ID  | EX  | DF  | WB  |     |
|            | Next instruction                 |     | IF  | ID  | EX  | MEM | WB  |

[Description] The pipeline consists of 5 stages, IF, ID, EX, DF, and WB.

## 8.2.7 Branch instructions

## (1) Conditional branch instructions (except BR instruction)

- [Instructions] Bcond instructions (BC, BE, BGE, BGT, BH, BL, BLE, BLT, BN, BNC, BNE, BNH, BNL, BNV, BNZ, BP, BSA, BV, BZ)
- [Pipeline] (a) When the condition is not satisfied

|                                   | <1> | <2> | <3> | <4> | <5> | <6> |  |
|-----------------------------------|-----|-----|-----|-----|-----|-----|--|
| Conditional branch<br>instruction | IF  | ID  | EX  | MEM | WB  |     |  |
| Next instruction                  |     | IF  | ID  | EX  | MEM | WB  |  |

#### (b) When the condition is satisfied

|                                   | <1>      | <2>  | <3> | <4> | <5> | <6> | <7> |
|-----------------------------------|----------|------|-----|-----|-----|-----|-----|
| Conditional branch<br>instruction | IF       | ID   | EX  | MEM | WB  |     |     |
| Next instruction                  |          | (IF) |     |     |     |     |     |
| Branch destination ins            | truction |      | IF  | ID  | EX  | MEM | WB  |

(IF): Instruction fetch that is not executed

- [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 the branch destination is decided in the ID stage.
  - (a) When the condition is not satisfied
     The number of execution clocks for the branch instruction is 1.
  - (b) When the condition is satisfied
     The number of execution clocks for the branch instruction is 2. IF stage of the next instruction of the branch instruction is not executed.
     If an instruction overwriting the contents of PSW occurs immediately before, the number of execution clocks is 3 because of flag hazard occurrence.

#### (2) BR instruction, unconditional branch instructions (except JMP instruction)

[Instructions] BR, JARL, JR

<1> <2> <7> [Pipeline] <3> <4> <5> <6> BR instruction, unconditional IF ID branch instruction ΕX мем WR (IF)Next instruction Branch destination instruction IF ID EX MEM WB

- (IF): Instruction fetch that is not executed
- WB\*: No operation is performed in the case of the JR and BR instructions but in the case of the JARL 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 EX, MEM, and WB stages, because the branch destination is decided in the ID stage. 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.

#### (3) JMP instruction

| [Pipeline] | <sup>&gt;</sup> ipeline] |         | <2>  | <3> | <4> | <5> | <6> | <7> |
|------------|--------------------------|---------|------|-----|-----|-----|-----|-----|
|            | JMP instruction          | IF      | ID   | EX  | MEM | WB  |     |     |
|            | Next instruction         |         | (IF) |     |     |     |     |     |
|            | Branch destination inst  | ruction |      | IF  | ID  | EX  | MEM | WB  |

- (IF): Instruction fetch that is not executed
- [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 the branch destination is decided in the ID stage.

#### 8.2.8 Bit manipulation instructions

### (1) CLR1, NOT1, SET1 instructions

| [Pipeline] |                                 | <1> | <2> | <3> | <4> | <5> | <6> | <7> | <8>        | <9> |
|------------|---------------------------------|-----|-----|-----|-----|-----|-----|-----|------------|-----|
|            | Bit manipulation<br>instruction | IF  | ID  | EX1 | MEM | EX2 | MEM | WB  | 1<br> <br> |     |
|            | Next instruction                |     | IF  | _   | _   | ID  | EX  | MEM | WB         |     |
|            | Next to next instructior        | ı   |     |     |     | IF  | ID  | EX  | MEM        | WB  |

<sup>-:</sup> Idle inserted for wait

[Description] The pipeline consists of 7 stages, IF, ID, EX1, MEM, EX2 (normal stage), 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, the EX stage requires a total of 2 clocks, and the MEM stage requires a total of 2 cycles.

#### (2) TST1 instruction

| [Pipeline] |                              | <1> | <2> | <3> | <4> | <5> | <6> | <7> | <8>        | <9> |
|------------|------------------------------|-----|-----|-----|-----|-----|-----|-----|------------|-----|
|            | Bit manipulation instruction | IF  | ID  | EX1 | MEM | EX2 | МЕМ | WB  | -<br> <br> | _   |
|            | Next instruction             |     | IF  | _   | _   | ID  | EX  | MEM | WB         |     |
|            | Next to next instructio      | n   |     |     |     | IF  | ID  | EX  | MEM        | WB  |

-: Idle inserted for wait

[Description] The pipeline consists of 7 stages, IF, ID, EX1, MEM, EX2 (normal stage), 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 all, this instruction requires 2 clocks.

#### 8.2.9 Special instructions

#### (1) CALLT instruction



(IF): Instruction fetch that is not executed

[Description] The pipeline consists of 6 stages, IF, ID, MEM, EX, MEM, and WB. However, no operation is performed in the second MEM and WB stages, because there is no memory access and no data is written to registers.

## (2) CTRET instruction



(IF): Instruction fetch that is not executed

[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 the branch destination is decided in the ID stage.

## (3) DI, EI instructions

|               | <1                                                | > <2> | <3> | <4> | <5>       | <6>                                                                        |
|---------------|---------------------------------------------------|-------|-----|-----|-----------|----------------------------------------------------------------------------|
| [Pipeline]    | DI, EI instruction IF                             | ID    | EX  | MEM | WB        |                                                                            |
|               | Next instruction                                  | IF    | ID  | EX  | MEM       | WB                                                                         |
| [Description] |                                                   |       | •   |     |           | M, and WB. However, no operation is nemory is not accessed and data is not |
| [Remark]      | Both the DI and EI ins<br>follows while these ins |       |     | •   | e an inte | errupt request. An interrupt is sampled as                                 |
|               |                                                   |       |     |     |           | 1                                                                          |

| Instruction immediately before | IF | ID      | EX                                                    | MEM   | WB               | ]                                                   | -      |
|--------------------------------|----|---------|-------------------------------------------------------|-------|------------------|-----------------------------------------------------|--------|
| DI, EI instruction             |    | IF      | ID                                                    | EX    | MEM              | WB                                                  | i<br>I |
| Instruction immediately after  |    |         | IF                                                    | ID    | EX               | MEM                                                 | WB     |
|                                |    |         |                                                       |       |                  |                                                     |        |
|                                |    | ir<br>e | ast sampl<br>iterrupt be<br>xecution of<br>istruction | efore | interr<br>I exec | l<br>sampling<br>rupt after<br>ution of E<br>uction |        |

## (4) **DISPOSE** instruction

| [Pipeline] | (a) When branch          | is not e | execute | d        |      |   |          |             |             |             |             |             |             |
|------------|--------------------------|----------|---------|----------|------|---|----------|-------------|-------------|-------------|-------------|-------------|-------------|
|            |                          | <1>      | <2>     | <3>      | <4>  |   | i        | <n+2></n+2> | <n+3></n+3> | <n+4></n+4> | <n+5></n+5> | <n+6></n+6> | <n+7></n+7> |
|            | DISPOSE instruction      | IF       | ID      | EX       | МЕМ  | Ľ | י<br>ג   | MEM         | MEM         | MEM         | WB          |             | -           |
|            | Next instruction         |          | IF      | _        | _    | Ĺ | )<br>(   | _           | ID          | EX          | MEM         | WB          |             |
|            | Next to next instruction | ı        |         |          |      |   | <i>,</i> |             | IF          | ID          | EX          | MEM         | WB          |
|            |                          | –: Idle  | inserte | ed for w | vait |   |          |             |             |             |             |             |             |

n: Number of registers specified in the register list (list12)

#### (b) When branch is executed



- (IF): Instruction fetch that is not executed
- -: Idle inserted for wait
- n: Number of registers specified in the register list (list12)
- [Description] The pipeline consists of n + 5 stages (n: register list number), IF, ID, EX, n + 1 times MEM, and WB. The MEM stage requires n + 1 cycles.

### (5) HALT instruction

#### [Pipeline]



[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 mode is released.

#### (6) LDSR, STSR instructions

|            |                           | <1> | <2> | <3> | <4> | <5> | <6> |
|------------|---------------------------|-----|-----|-----|-----|-----|-----|
| [Pipeline] | LDSR, STSR<br>instruction | IF  | ID  | EX  | DF  | WB  |     |
|            | Next instruction          |     | IF  | ID  | EX  | MEM | WB  |

[Description] The pipeline consists of 5 stages, IF, ID, EX, DF, and WB. 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.

## (7) NOP instruction

|            |                  | <1> | <2> | <3> | <4> | <5> | <6> |
|------------|------------------|-----|-----|-----|-----|-----|-----|
| [Pipeline] | NOP instruction  | IF  | ID  | EX  | MEM | WB  |     |
|            | Next 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 EX, MEM, and WB stages, because no operation and no memory access is executed, and no data is written to registers.

Caution Be aware that the SLD and Bcond instructions are sometimes executed at the same time as other 16-bit format instructions. For example, if the SLD and NOP instructions are executed simultaneously, the NOP instruction may keep the delay time from being generated.

#### (8) **PREPARE** instruction

| [Pipeline] |                          | <1>    | <2>     | <3>     | <4> | <       | ۷      | <n+2></n+2> | <n+3></n+3> | <n+4></n+4> | <n+5></n+5> | <n+6></n+6> | <n+7></n+7> |
|------------|--------------------------|--------|---------|---------|-----|---------|--------|-------------|-------------|-------------|-------------|-------------|-------------|
|            | PREPARE instruction      | IF     | ID      | EX      | MEM | Ľ       | /      | MEM         | MEM         | MEM         | WB          |             |             |
|            | Next instruction         |        | IF      | -       | -   | $\Box'$ | ,<br>{ | 1           | ID          | EX          | MEM         | WB          |             |
|            | Next to next instruction |        |         |         |     | ,       | )      |             | IF          | ID          | EX          | MEM         | WB          |
|            |                          |        |         |         |     |         |        |             |             |             |             |             |             |
|            |                          | · Idlo | incorto | d for w | ait |         |        |             |             |             |             |             |             |

Idle inserted for wait

n: Number of registers specified in the register list (list12)

[Description] The pipeline consists of n + 5 stages (n: register list number), IF, ID, EX, n + 1 times MEM, and WB. The MEM stage requires n + 1 cycles.

## (9) RETI instruction



- (IF): Instruction fetch that is not executed
- ID1: Register selection
- ID2: 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 stages of the next instruction and next to next instruction are not executed.

## (10)SWITCH instruction



(IF): Instruction fetch that is not executed

[Description] The pipeline consists of 7 stages, IF, ID, EX1 (normal EX stage), MEM, EX2, MEM, and WB. However, no operation is performed in the second MEM and WB stages, because there is no memory access and no data is written to registers.

### (11) TRAP instruction



- (IF): Instruction fetch that is not executed
- ID1: Exception code (004nH, 005nH) detection (n = 0 to FH)
- ID2: Address generation
- [Description] The pipeline consists of 6 stages, IF, ID1, ID2, EX, DF, and WB. The ID stage requires 2 clocks. Also, the IF stages of the next instruction and next to next instruction are not executed.

## 8.2.10 Debug function instructions

## (1) DBRET instruction



[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 the memory is not accessed and no data is written to registers. The ID stage requires 2 clocks. Also, the IF stages of the next instruction and next to next instruction are not executed.

## (2) DBTRAP instruction



- ID1: Exception code (0060H) detection
- ID2: Address generation
- [Description] The pipeline consists of 6 stages, IF, ID1, ID2, EX, MEM, and WB. The ID stage requires 2 clocks. Also, the IF stages of the next instruction and next to next instruction are 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 an align hazard.

For example, the 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 = 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-6. Align Hazard Example

Align hazards 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 V850ES CPU has an interlock function to automatically handle this hazard by delaying the ID stage of the next instruction.

The V850ES CPU 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.





As shown in Figure 8-7, 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, 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 V850ES CPU'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-8. Example of Execution Result of Multiply Instruction

As shown in Figure 8-8, 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. However, in the case of the word data multiply instructions (MUL, MULU), if the instruction that uses the result of the multiply instruction is not place at least five instructions after the multiply instruction, an IL stage is inserted between 1 and 4.

## 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 V850ES CPU'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.

Figure 8-9. Example of Referencing Execution Result of LDSR Instruction for EIPC and FEPC



As shown in Figure 8-9, 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 V850ES CPU uses the Harvard architecture to operate an instruction fetch path from internal ROM and a memory access path to internal RAM independently. This eliminates bus arbitration conflicts between the IF and MEM stages and allows orderly pipeline operation.

### (1) V850ES CPU (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.



## (2) Not V850ES CPU (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 bus waiting to occur and slower execution time due to disorderly pipeline operation.



## 8.4.2 Short path

The V850ES CPU 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
  - V850ES CPU (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.



## • Not V850ES CPU (No short path)

The ID stage of the instruction following immediately after is delayed until write back of the previous instruction is completed.



Example 2. Data read from memory by the load instruction used by instruction following immediately after

• V850ES CPU (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.



• Not V850ES CPU (No short path)

The ID stage of the instruction following immediately after is delayed until write back of the previous instruction is completed.

|                          |    |         |    |                          |                | <6>       | <7>       | <8> | <9> | <10> |
|--------------------------|----|---------|----|--------------------------|----------------|-----------|-----------|-----|-----|------|
| LD [R4], R6              | IF | ID      | EX | MEM                      | WB             | ]         |           |     | _   |      |
| ADD 2, R6                |    | IF      | -  | -                        | ID             | EX        | MEM       | WB  |     | _    |
| Next instruction         |    |         |    |                          | IF             | ID        | EX        | MEM | WB  |      |
| Next to next instruction | on |         |    |                          |                | IF        | ID        | EX  | MEM | WB   |
|                          |    | -: Idle |    | d for data<br>d for wait | a wait by<br>t | interlocl | k functio | n   |     |      |

## APPENDIX A INSTRUCTION LIST

The instruction function list in alphabetical order is shown in Table A-1, and instruction list in format order is shown in Table A-2.

| Mnemonic | Operand              | Format |     |     | Flag |     |     | Instruction Function                                                                                                                                                                                                                                                                                                                                              |
|----------|----------------------|--------|-----|-----|------|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |                      |        | CY  | OV  | S    | Z   | SAT |                                                                                                                                                                                                                                                                                                                                                                   |
| ADD      | reg1, reg2           | I      | 0/1 | 0/1 | 0/1  | 0/1 | -   | Add. Adds the word data of reg1 to the word data of reg2, and stores the result to reg2.                                                                                                                                                                                                                                                                          |
| ADD      | imm5, reg2           | Π      | 0/1 | 0/1 | 0/1  | 0/1 | _   | Add. Adds the 5-bit immediate data, sign-<br>extended to word length, to the word data of<br>reg2, and stores the result to reg2.                                                                                                                                                                                                                                 |
| ADDI     | imm16, reg1, reg2    | VI     | 0/1 | 0/1 | 0/1  | 0/1 | _   | Add Immediate. 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           | Ι      | -   | 0   | 0/1  | 0/1 | _   | 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   | 0/1  | 0/1 | -   | And. ANDs the word data of reg1 with the 16-<br>bit immediate data, zero-extended to word<br>length, and stores the result to reg2.                                                                                                                                                                                                                               |
| Bcond    | disp9                | III    | _   | _   | _    | _   | _   | Branch on Condition Code. Tests a condition<br>flag specified by an instruction. Branches if a<br>specified condition is satisfied; otherwise,<br>executes the next instruction. The branch<br>destination PC holds the sum of the current<br>PC value and 9-bit displacement which is the<br>8-bit immediate shifted 1 bit and sign-<br>extended to word length. |
| BSH      | reg2, reg3           | XII    | 0/1 | 0   | 0/1  | 0/1 | -   | Byte Swap Halfword. Performs endian conversion.                                                                                                                                                                                                                                                                                                                   |
| BSW      | reg2, reg3           | XII    | 0/1 | 0   | 0/1  | 0/1 | -   | Byte Swap Word. Performs endian<br>conversion.                                                                                                                                                                                                                                                                                                                    |
| CALLT    | imm6                 | II     | -   | -   | _    | -   | _   | Call with Table Look Up. Based on CTBP contents, updates PC value and transfers control.                                                                                                                                                                                                                                                                          |
| CLR1     | bit#3, disp16 [reg1] | VIII   | _   | _   | _    | 0/1 | _   | Clear Bit. Adds the data of reg1 to a 16-bit<br>displacement, sign-extended to word length,<br>to generate a 32-bit address. Then clears the<br>bit, specified by the instruction bit field, of the<br>byte data referenced by the generated<br>address.                                                                                                          |

| Table A-1. | Instruction Function Li | st (in Al  | phabetical | Order) (1/11) |
|------------|-------------------------|------------|------------|---------------|
|            |                         | 3t (iii Ai | phasedoal  |               |

| Mnemonic | Operand                   | Format |     |     | Flag |     |     | Instruction Function                                                                                                                                                                                                                                                         |
|----------|---------------------------|--------|-----|-----|------|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |                           |        | CY  | ov  | S    | Z   | SAT |                                                                                                                                                                                                                                                                              |
| CLR1     | reg2 [reg1]               | IX     | -   | -   | -    | 0/1 | -   | Clear Bit. First, reads the data of reg1 to generate a 32-bit address. Then clears the bit, specified by the data of lower 3 bits of reg2 of the byte data referenced by the generated address.                                                                              |
| CMOV     | cccc, reg1, reg2,<br>reg3 | XI     | -   | _   | _    | -   | _   | Conditional Move. reg3 is set to reg1 if a condition specified by condition code "cccc" is satisfied; otherwise, set to the data of reg2.                                                                                                                                    |
| CMOV     | cccc, imm5, reg2,<br>reg3 | XII    | -   | _   | _    | _   | -   | Conditional Move. reg3 is set to the data of 5-<br>immediate, sign-extended to word length, if a<br>condition specified by condition code "cccc" is<br>satisfied; otherwise, set to the data of reg2.                                                                        |
| СМР      | reg1, reg2                | I      | 0/1 | 0/1 | 0/1  | 0/1 | _   | Compare. Compares the word data of reg2<br>with the word data of reg1, and indicates the<br>result by using the PSW flags. To compare,<br>the contents of reg1 are subtracted from the<br>word data of reg2.                                                                 |
| СМР      | imm5, reg2                | II     | 0/1 | 0/1 | 0/1  | 0/1 | _   | Compare. Compares the word data of reg2<br>with the 5-bit immediate data, sign-extended<br>to word length, and indicates the result by<br>using the PSW flags. To compare, the<br>contents of the sign-extended immediate data<br>are subtracted from the word data of reg2. |
| CTRET    | (None)                    | х      | 0/1 | 0/1 | 0/1  | 0/1 | 0/1 | Restore from CALLT. Restores the restore PC<br>and PSW from the appropriate system register<br>and restores from a routine called by CALLT.                                                                                                                                  |
| DBRET    | (None)                    | х      | 0/1 | 0/1 | 0/1  | 0/1 | 0/1 | Return from debug trap. Restores the restore<br>PC and PSW from the appropriate system<br>register and restores from a debug monitor<br>routine.                                                                                                                             |
| DBTRAP   | (None)                    | I      | _   | _   | _    | _   | _   | Debug trap. Saves the restore PC and PSW to the appropriate system register and transfers control by setting the PC to handler address (00000060H).                                                                                                                          |
| DI       | (None)                    | X      | _   | _   | _    | _   | _   | Disables Interrupt. Sets the ID flag of the PSW<br>to 1 to disable the acknowledgement of<br>maskable interrupts from acceptance;<br>interrupts are immediately disabled at the start<br>of this instruction execution.                                                      |
| DISPOSE  | imm5, list12              | XIII   | -   | -   | -    | -   | -   | Function Dispose. Adds the data of 5-bit<br>immediate imm5, logically shifted left by 2 and<br>zero-extended to word length, to sp. Then pop<br>(load data from the address specified by sp<br>and adds 4 to sp) general-purpose registers<br>listed in list12.              |

## Table A-1. Instruction Function List (in Alphabetical Order) (2/11)

| Mnemonic | Operand              | Format |     |     | Flag |     |     | Instruction Function                                                                                                                                                                                                                                                                                                   |
|----------|----------------------|--------|-----|-----|------|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |                      |        | CY  | ov  | S    | Z   | SAT |                                                                                                                                                                                                                                                                                                                        |
| DISPOSE  | imm5, list12, [reg1] | XIII   | _   | _   | _    | _   | _   | Function Dispose. Adds the data of 5-bit<br>immediate imm5, logically shifted left by 2 and<br>zero-extended to word length, to sp. Then pop<br>(load data from the address specified by sp<br>and adds 4 to sp) general-purpose registers<br>listed in list12, transfers control to the address<br>specified by reg1. |
| DIV      | reg1, reg2, reg3     | XI     | _   | 0/1 | 0/1  | 0/1 | _   | Divide Word. Divides the word data of reg2 by<br>the word data of reg1, and stores the quotient<br>to reg2 and the remainder to reg3.                                                                                                                                                                                  |
| DIVH     | reg1, reg2           | I      | -   | 0/1 | 0/1  | 0/1 | -   | Divide Halfword. Divides the word data of reg2<br>by the lower halfword data of reg1, and stores<br>the quotient to reg2.                                                                                                                                                                                              |
| DIVH     | reg1, reg2, reg3     | XI     | -   | 0/1 | 0/1  | 0/1 | _   | Divide Halfword. Divides word data of reg2 by<br>lower halfword data of reg1, and stores the<br>quotient to reg2 and the remainder to reg3.                                                                                                                                                                            |
| DIVHU    | reg1, reg2, reg3     | XI     | _   | 0/1 | 0/1  | 0/1 | _   | Divide Halfword Unsigned. Divides word data<br>of reg2 by lower halfword data of reg1, and<br>stores the quotient to reg2 and the remainder<br>to reg3.                                                                                                                                                                |
| DIVU     | reg1, reg2, reg3     | XI     | _   | 0/1 | 0/1  | 0/1 | _   | Divide Word Unsigned. Divides the word data<br>of reg2 by the word data of reg1, and stores<br>the quotient to reg2 and the remainder to<br>reg3.                                                                                                                                                                      |
| EI       | (None)               | Х      | _   | _   | _    | _   | _   | Enable Interrupt. Clears the ID flag of the PSW to 0 and enables the acknowledgement of maskable interrupts at the beginning of next instruction.                                                                                                                                                                      |
| HALT     | (None)               | х      | -   | -   | -    | -   | -   | Halt. Stops the operating clock of the CPU and places the CPU in the HALT mode.                                                                                                                                                                                                                                        |
| HSW      | reg2, reg3           | XII    | 0/1 | 0   | 0/1  | 0/1 | -   | Halfword Swap Word. Performs endian conversion.                                                                                                                                                                                                                                                                        |
| JARL     | disp22, reg2         | V      | -   | _   | _    | _   | _   | Jump and Register Link. Saves the current PC value plus 4 to general-purpose 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      | -   | -   | -    | _   | -   | Jump Register. Transfers control to the address specified by reg1. Bit 0 of the address is masked to 0.                                                                                                                                                                                                                |
| JR       | disp22               | V      | _   | _   | _    | _   | _   | Jump Relative. Adds a 22-bit displacement,<br>sign-extended to word length, to the current<br>PC value, and transfers control to the PC. Bit<br>0 of the 22-bit displacement is masked to 0.                                                                                                                           |

# Table A-1. Instruction Function List (in Alphabetical Order) (3/11)

| Mnemonic | Operand             | Format |    |    | Flag |   |     | Instruction Function                                                                                                                                                                                                                                                                |
|----------|---------------------|--------|----|----|------|---|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |                     |        | CY | ov | S    | Z | SAT |                                                                                                                                                                                                                                                                                     |
| 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 in reg2.                                                         |
| LD.BU    | disp16 [reg1], reg2 | VII    | _  | _  | _    | _ | _   | Unsigned Byte Load. Adds the data of reg1<br>and the 16-bit displacement sign-extended to<br>word length, and generates a 32-bit address.<br>Then reads the byte data from the generated<br>address, zero-extends it to word length, and<br>stores it in reg2.                      |
| LD.H     | disp16 [reg1], reg2 | VII    | _  | _  | _    | _ | _   | Halfword Load. Adds the data of reg1 to a 16-<br>bit displacement, sign-extended to word<br>length, to generate a 32-bit address. Halfword<br>data is read from this 32-bit address with bit 0<br>masked to 0, sign-extended to word length,<br>and stored in reg2.                 |
| LD.HU    | disp16 [reg1], reg2 | VII    | _  | _  | _    | _ | _   | Unsigned Halfword Load. Adds the data of reg1 and the 16-bit displacement sign-<br>extended to word length to generate a 32-bit address. Reads the halfword data from the address masking bit 0 of this 32-bit address to 0, zero-extends it to word length, and stores it in 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 in reg2.                                                                |
| LDSR     | reg2, regID         | IX     | _  | _  | _    | _ | _   | Load to System Register. Set the word data of<br>reg2 to a system register specified by regID. If<br>regID is PSW, the values of the corresponding<br>bits of reg2 are set to the respective flags of<br>the PSW.                                                                   |
| MOV      | reg1, reg2          | I      | _  | -  | _    | - | -   | Move. Transfers the word data of reg1 to reg2.                                                                                                                                                                                                                                      |
| MOV      | imm5, reg2          | II     | _  | -  | _    | - | _   | Move. Transfers the value of a 5-bit immediate data, sign-extended to word length, to reg2.                                                                                                                                                                                         |
| MOV      | imm32, reg1         | VI     | -  | -  | -    | - | -   | Move. Transfers the 32-bit immediate data to reg1.                                                                                                                                                                                                                                  |
| MOVEA    | imm16, reg1, reg2   | VI     | _  | _  | _    | _ | _   | Move Effective Address. Adds a 16-bit immediate data, sign-extended to word length, to the word data of reg1, and stores the result in reg2.                                                                                                                                        |

## Table A-1. Instruction Function List (in Alphabetical Order) (4/11)

| Mnemonic | Operand              | Format |    |    | Flag |     |     | Instruction Function                                                                                                                                                                                                                             |
|----------|----------------------|--------|----|----|------|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |                      |        | CY | OV | S    | Z   | SAT |                                                                                                                                                                                                                                                  |
| MOVHI    | imm16, reg1, reg2    | VI     | _  | _  | _    | _   | _   | Move High Halfword. Adds word data, in which the higher 16 bits are defined by the 16-<br>bit immediate data while the lower 16 bits are<br>set to 0, to the word data of reg1 and stores<br>the result in reg2.                                 |
| MUL      | reg1, reg2, reg3     | XI     | _  | _  | _    | _   | _   | Multiply Word. Multiplies the word data of reg2<br>by the word data of reg1, and stores the result<br>in reg2 and reg3 as double-word data.                                                                                                      |
| MUL      | imm9, reg2, reg3     | XII    | _  | _  | _    | _   | _   | Multiply Word. Multiplies the word data of reg2<br>by the 9-bit immediate data sign-extended to<br>word length, and stores the result in reg2 and<br>reg3.                                                                                       |
| MULH     | reg1, reg2           | I      | _  | _  | _    | _   | _   | Multiply Halfword. Multiplies the lower<br>halfword data of reg2 by the lower halfword<br>data of reg1, and stores the result in reg2 as<br>word data.                                                                                           |
| MULH     | imm5, reg2           | II     | _  | _  | _    | _   | _   | Multiply Halfword. Multiplies the lower<br>halfword data of reg2 by a 5-bit immediate<br>data, sign-extended to halfword length, and<br>stores the result in reg2 as word data.                                                                  |
| MULHI    | imm16, reg1, reg2    | VI     | _  | -  | -    | _   | -   | Multiply Halfword Immediate. Multiplies the lower halfword data of reg1 by a 16-bit immediate data, and stores the result in reg2.                                                                                                               |
| MULU     | reg1, reg2, reg3     | XI     | _  | _  | _    | _   | _   | Multiply Word Unsigned. Multiplies the word data of reg2 by the word data of reg1, and stores the result in reg2 and reg3 as double-word data. reg1 is not affected.                                                                             |
| MULU     | imm9, reg2, reg3     | XII    | _  | _  | _    | _   | _   | Multiply Word Unsigned. Multiplies the word data of reg2 by the 9-bit immediate data sign-<br>extended to word length, and store the result in reg2 and reg3.                                                                                    |
| NOP      | (None)               | I      | -  | -  | -    | -   | -   | No Operation.                                                                                                                                                                                                                                    |
| NOT      | reg1, reg2           | Ι      | _  | 0  | 0/1  | 0/1 | _   | Not. Logically negates (takes 1's complement of) the word data of reg1, and stores the result in reg2.                                                                                                                                           |
| NOT1     | bit#3, disp16 [reg1] | VIII   | _  | _  | -    | 0/1 | _   | Not Bit. 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 bit number is inverted at the byte data location referenced by the generated address. |
| NOT1     | reg2, [reg1]         | IX     | _  | _  | _    | 0/1 | _   | Not Bit. First, reads reg1 to generate a 32-bit address. The bit specified by the lower 3 bits of reg2 of the byte data of the generated address is inverted.                                                                                    |

## Table A-1. Instruction Function List (in Alphabetical Order) (5/11)

| Mnemonic | Operand                 | Format |     |     | Flag |     |     | Instruction Function                                                                                                                                                                                                                                                                                                                                   |
|----------|-------------------------|--------|-----|-----|------|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |                         |        | CY  | ov  | S    | Z   | SAT |                                                                                                                                                                                                                                                                                                                                                        |
| OR       | reg1, reg2              | I      | _   | 0   | 0/1  | 0/1 | -   | Or. ORs the word data of reg2 with the word data of reg1, and stores the result in reg2.                                                                                                                                                                                                                                                               |
| ORI      | imm16, reg1, reg2       | VI     | _   | 0   | 0/1  | 0/1 | _   | Or Immediate. ORs the word data of reg1 with<br>the 16-bit immediate data, zero-extended to<br>word length, and stores the result in reg2.                                                                                                                                                                                                             |
| PREPARE  | list12, imm5            | ХШ     | _   | _   | _    | _   | _   | Function Prepare. The general-purpose register displayed in list12 is saved (4 is subtracted from sp, and the data is stored in that address). Next, the data is logically shifted 2 bits to the left, and the 5-bit immediate data zero-extended to word length is subtracted from sp.                                                                |
| PREPARE  | list12, imm5,<br>sp/imm | XIII   | _   | _   | _    | _   | _   | Function Prepare. The general-purpose register displayed in list12 is saved (4 is subtracted from sp, and the data is stored in that address). Next, the data is logically shifted 2 bits to the left, and the 5-bit immediate data zero-extended to word length is subtracted from sp. Then, the data specified by the third operand is loaded to ep. |
| RETI     | (None)                  | х      | 0/1 | 0/1 | 0/1  | 0/1 | 0/1 | Return from Trap or Interrupt. Reads the restore PC and PSW from the appropriate system register, and restores from interrupt or exception processing routine.                                                                                                                                                                                         |
| SAR      | reg1, reg2              | IX     | 0/1 | 0   | 0/1  | 0/1 | _   | Shift Arithmetic Right. 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/1 | 0   | 0/1  | 0/1 | _   | Shift Arithmetic Right. Arithmetically shifts the word data of reg2 to the right by 'n' positions specified by the lower 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.                                                                   |
| SASF     | cccc, reg2              | IX     | _   | _   | _    | _   | _   | Shift and Set Flag Condition. reg2 is logically<br>shifted left by 1, and its LSB is set to 1 in a<br>condition specified by condition code "cccc" is<br>satisfied; otherwise, LSB is set to 0.                                                                                                                                                        |

## Table A-1. Instruction Function List (in Alphabetical Order) (6/11)

| Mnemonic | Operand              | Format |     |     | Flag |     |     | Instruction Function                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------|----------------------|--------|-----|-----|------|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |                      |        | CY  | OV  | S    | Z   | SAT |                                                                                                                                                                                                                                                                                                                                                                                                                          |
| SATADD   | reg1, reg2           | Ι      | 0/1 | 0/1 | 0/1  | 0/1 | 0/1 | Saturated Add. Adds the word data of reg1 to<br>the word data of reg2, and stores the result in<br>reg2. However, if the result exceeds the<br>maximum positive value, the maximum<br>positive value is stored in reg2; if the result<br>exceeds the maximum negative value, the<br>maximum negative value is stored in reg2.<br>The SAT flag is set to 1.                                                               |
| SATADD   | imm5, reg2           | Π      | 0/1 | 0/1 | 0/1  | 0/1 | 0/1 | Saturated Add. Adds the 5-bit immediate data,<br>sign-extended to word length, to the word data<br>of reg2, and stores the result in reg2.<br>However, if the result exceeds the maximum<br>positive value, the maximum positive value is<br>stored in reg2; if the result exceeds the<br>maximum negative value, the maximum<br>negative value is stored in reg2. The SAT flag<br>is set to 1.                          |
| SATSUB   | reg1, reg2           | I      | 0/1 | 0/1 | 0/1  | 0/1 | 0/1 | Saturated Subtract. Subtracts the word data of reg1 from the word data of reg2, and stores the result in reg2. However, if the result exceeds the maximum positive value, the maximum positive value is stored in reg2; if the result exceeds the maximum negative value, the maximum negative value, the maximum negative value, the SAT flag is set to 1.                                                              |
| SATSUBI  | imm16, reg1, reg2    | VI     | 0/1 | 0/1 | 0/1  | 0/1 | 0/1 | Saturated Subtract Immediate. Subtracts a 16-bit immediate data, sign-extended to word length, from the word data of reg1, and stores the result in reg2. However, if the result exceeds the maximum positive value, the maximum positive value is stored in reg2; if the result exceeds the maximum negative value, the maximum negative value, the maximum negative value is stored in reg2. The SAT flag is set to 1. |
| SATSUBR  | reg1, reg2           | I      | 0/1 | 0/1 | 0/1  | 0/1 | 0/1 | Saturated Subtract Reverse. Subtracts the word data of reg2 from the word data of reg1, and stores the result in reg2. However, if the result exceeds the maximum positive value, the maximum positive value is stored in reg2; if the result exceeds the maximum negative value, the maximum negative value, the maximum negative value is stored in reg2. The SAT flag is set to 1.                                    |
| SET1     | bit#3, disp16 [reg1] | VIII   | -   | -   | -    | 0/1 | -   | Set Bit. First, adds a 16-bit displacement,<br>sign-extended to word length, to the data of<br>reg1 to generate a 32-bit address. The bits,<br>specified by the 3-bit bit number, are set at the<br>byte data location specified by the generated<br>address.                                                                                                                                                            |

# Table A-1. Instruction Function List (in Alphabetical Order) (7/11)

| Mnemonic | Operand          | Format |     |    | Flag |     |     | Instruction Function                                                                                                                                                                                                                             |
|----------|------------------|--------|-----|----|------|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |                  |        | CY  | ov | S    | Z   | SAT |                                                                                                                                                                                                                                                  |
| SET1     | reg2, [reg1]     | IX     | _   | _  | _    | 0/1 | _   | Set Bit. First, reads the data of general-<br>purpose register reg1 to generate a 32-bit<br>address. The bit, specified by the data of<br>lower 3 bits of reg2, is set at the byte data<br>location referenced by the generated address.         |
| 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 in reg2.                                                                                                       |
| SHL      | reg1, reg2       | IX     | 0/1 | 0  | 0/1  | 0/1 | -   | Shift Logical Left. 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 then writes the result to reg2.                                  |
| SHL      | imm5, reg2       | II     | 0/1 | 0  | 0/1  | 0/1 | _   | Shift Logical Left. 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 then writes the result to reg2.      |
| SHR      | reg1, reg2       | IX     | 0/1 | 0  | 0/1  | 0/1 | _   | Shift Logical Right. 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 then writes the result to reg2.                                |
| SHR      | imm5, reg2       | II     | 0/1 | 0  | 0/1  | 0/1 | _   | Shift Logical Right. 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 then writes the result to reg2.    |
| SLD.B    | disp7 [ep], reg2 | IV     | _   | _  | _    | _   | -   | Byte Load. Adds the 7-bit displacement, zero-<br>extended to word length, to the element<br>pointer to generate a 32-bit address. Byte data<br>is read from the generated address, sign-<br>extended to word length, and then stored in<br>reg2. |
| SLD.BU   | disp4 [ep], reg2 | IV     | -   | _  | _    | _   | _   | Unsigned Byte Load. Adds the 4-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, zero-extended to word length, and stored in reg2.              |
| SLD.H    | disp8 [ep], reg2 | IV     | _   | _  | _    | _   | _   | Halfword Load. Adds the 8-bit displacement,<br>zero-extended to word length, to the element<br>pointer to generate a 32-bit address. Halfword<br>data is read from the generated address, sign-<br>extended to word length, and stored in reg2.  |

# Table A-1. Instruction Function List (in Alphabetical Order) (8/11)

| Mnemonic | Operand             | Format |    |    | Flag |   |     | Instruction Function                                                                                                                                                                                                                        |
|----------|---------------------|--------|----|----|------|---|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |                     |        | CY | ov | S    | Z | SAT |                                                                                                                                                                                                                                             |
| SLD.HU   | disp5 [ep], reg2    | IV     | -  | -  | _    | _ | _   | Unsigned Halfword Load. Adds the 5-bit displacement, zero-extended to word length, to the element pointer to generate a 32-bit address. Halfword data is read from the generated address, zero-extended to word length, and stored in reg2. |
| SLD.W    | disp8 [ep], reg2    | IV     | _  | _  | _    | _ | -   | Word Load. Adds the 8-bit displacement, zero-<br>extended to word length, to the element<br>pointer to generate a 32-bit address. Word<br>data is read from the generated address, and<br>stored in reg2.                                   |
| SST.B    | reg2, disp7 [ep]    | IV     | _  | _  | _    | _ | -   | Byte Store. Adds the 7-bit displacement, zero-<br>extended to word length, to the element<br>pointer to generate a 32-bit address, and<br>stores the data of the lowest byte of reg2 in<br>the generated address.                           |
| SST.H    | reg2, disp8 [ep]    | IV     | -  | -  | -    | - | -   | Halfword 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 halfword of reg2 in the generated address.                                             |
| 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 in the generated addres.                                                       |
| ST.B     | reg2, disp16 [reg1] | VII    | _  | _  | _    | _ | _   | Byte 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 lowest byte data of reg2 in the generated address.                                                 |
| ST.H     | reg2, disp16 [reg1] | VII    | _  | -  | _    | _ | _   | Halfword 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 halfword of reg2 in the generated address.                                               |
| ST.W     | reg2, disp16 [reg1] | VII    | -  | -  | _    | - | _   | 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 word data of reg2 in the generated address.                                                        |
| STSR     | regID, reg2         | IX     | _  | -  | _    | _ | _   | Store Contents of System Register. Stores the contents of a system register specified by regID in reg2.                                                                                                                                     |

# Table A-1. Instruction Function List (in Alphabetical Order) (9/11)

| Mnemonic | Operand              | Format |     |     | Flag |     |     | Instruction Function                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------|----------------------|--------|-----|-----|------|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |                      |        | CY  | ov  | S    | Z   | SAT |                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| SUB      | reg1, reg2           | Ι      | 0/1 | 0/1 | 0/1  | 0/1 | -   | Subtract. Subtracts the word data of reg1 from the word data of reg2, and stores the result in reg2.                                                                                                                                                                                                                                                                                                                                                                          |
| SUBR     | reg1, reg2           | Ι      | 0/1 | 0/1 | 0/1  | 0/1 | _   | Subtract Reverse. Subtracts the word data of reg2 from the word data of reg1, and stores the result in reg2.                                                                                                                                                                                                                                                                                                                                                                  |
| SWITCH   | reg1                 | I      | _   | _   | _    | _   | _   | Jump with Table Look Up. Adds the table<br>entry address (address following SWITCH<br>instruction) and data of reg1 logically shifted<br>to the left by 1 bit, and loads the halfword<br>entry data specified by the table entry<br>address. Next, logically shifts to the left by 1<br>bit the loaded data, and after sign-extending it<br>to word length, branches to the target address<br>added to the table entry address (instruction<br>following SWITCH instruction). |
| SXB      | reg1                 | I      | -   | -   | -    | -   | -   | Sign Extend Byte. Sign-extends the lowermost byte of reg1 to word length.                                                                                                                                                                                                                                                                                                                                                                                                     |
| SXH      | reg1                 | I      | -   | -   | -    | -   | _   | Sign Extend Halfword. Sign-extends lower halfword of reg1 to word length.                                                                                                                                                                                                                                                                                                                                                                                                     |
| TRAP     | vector               | Х      | _   | _   | _    | _   | _   | Trap. Saves the restore PC and PSW; sets<br>the exception code and the flags of the PSW;<br>jumps to the address of the trap handler<br>corresponding to the trap vector specified by<br>vector, and starts exception processing.                                                                                                                                                                                                                                             |
| TST      | reg1, reg2           | I      | -   | 0   | 0/1  | 0/1 | _   | 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   | -   | -   | -    | 0/1 | _   | Test Bit. 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 bit number, 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 cleared to 0.                                                                                                                         |
| TST1     | reg2, [reg1]         | IX     | -   | -   | -    | 0/1 | -   | Test Bit. First, reads the data of reg1 to generate a 32-bit address. If the bits indicated by the lower 3 bits of reg2 of the byte data of the generated address are 0, the Z flag is set to 1, and if they are 1, the Z flag is cleared to 0.                                                                                                                                                                                                                               |
| XOR      | reg1, reg2           | I      | _   | 0   | 0/1  | 0/1 | -   | Exclusive Or. Exclusively ORs the word data of reg2 with the word data of reg1, and stores the result in reg2.                                                                                                                                                                                                                                                                                                                                                                |

## Table A-1. Instruction Function List (in Alphabetical Order) (10/11)

| Mnemonic | Operand           | Format | Flag |    |     |     |     | Instruction Function                                                                                                                                     |
|----------|-------------------|--------|------|----|-----|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |                   |        | CY   | ov | S   | Z   | SAT |                                                                                                                                                          |
| XORI     | imm16, reg1, reg2 | VI     | _    | 0  | 0/1 | 0/1 | _   | 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 in reg2. |
| ZXB      | reg1              | I      | -    | -  | -   | -   | -   | Zero Extend Byte. Zero-extends to word length the lowest byte of reg1.                                                                                   |
| ZXH      | reg1              | I      | _    | _  | _   | -   | _   | Zero Extend Halfword. Zero-extends to word length the lower halfword of reg1.                                                                            |

## Table A-1. Instruction Function List (in Alphabetical Order) (11/11)

| Format | Орс                                     | code  | Mnemonic | Operand    |
|--------|-----------------------------------------|-------|----------|------------|
|        | 15 0                                    | 31 16 |          |            |
| I      | 000000000000000000000000000000000000000 | _     | NOP      | -          |
|        | rrrr000000RRRRR                         | _     | MOV      | reg1, reg2 |
|        | rrrrr000001RRRRR                        | -     | NOT      | reg1, reg2 |
|        | rrrr000010RRRR                          | -     | DIVH     | reg1, reg2 |
|        | 00000000010RRRR                         | -     | SWITCH   | reg1       |
|        | 00000000011RRRRR                        | -     | JMP      | [reg1]     |
|        | rrrr000100RRRRR                         | -     | SATSUBR  | reg1, reg2 |
|        | rrrrr000101RRRRR                        | -     | SATSUB   | reg1, reg2 |
|        | rrrr000110RRRR                          | -     | SATADD   | reg1, reg2 |
|        | rrrrr000111RRRRR                        | -     | MULH     | reg1, reg2 |
|        | 00000000100RRRR                         | -     | ZXB      | reg1       |
|        | 00000000101RRRRR                        | -     | SXB      | reg1       |
|        | 00000000110RRRR                         | -     | ZXH      | reg1       |
|        | 00000000111RRRRR                        | -     | SXH      | reg1       |
|        | rrrrr001000RRRRR                        | -     | OR       | reg1, reg2 |
|        | rrrrr001001RRRRR                        | _     | XOR      | reg1, reg2 |
|        | rrrr001010RRRRR                         | -     | AND      | reg1, reg2 |
|        | rrrrr001011RRRRR                        | _     | TST      | reg1, reg2 |
|        | rrrrr001100RRRRR                        | _     | SUBR     | reg1, reg2 |
|        | rrrr001101RRRRR                         | _     | SUB      | reg1, reg2 |
|        | rrrrr001110RRRRR                        | _     | ADD      | reg1, reg2 |
|        | rrrr001111RRRRR                         | _     | CMP      | reg1, reg2 |
|        | 111110000100000                         | _     | DBTRAP   | -          |
| П      | rrrrr010000iiiii                        | _     | MOV      | imm5, reg2 |
|        | rrrrr010001iiiii                        | _     | SATADD   | imm5, reg2 |
|        | rrrrr010010iiiii                        | _     | ADD      | imm5, reg2 |
|        | rrrrr010011iiiii                        | _     | CMP      | imm5, reg2 |
|        | 000001000iiiiii                         | _     | CALLT    | imm6       |
|        | rrrrr010100iiiii                        | _     | SHR      | imm5, reg2 |
|        | rrrrr010101iiiii                        | _     | SAR      | imm5, reg2 |
|        | rrrrr010110iiiii                        | _     | SHL      | imm5, reg2 |
|        | rrrrr010111iiiii                        | _     | MULH     | imm5, reg2 |
| Ш      | ddddd1011dddCCCC                        | -     | Bcond    | disp9      |

## Table A-2. Instruction List (in Format Order) (1/3)

| Format | Орс              | code             | Mnemonic | Operand              |
|--------|------------------|------------------|----------|----------------------|
|        | 15 0             | 31 16            |          |                      |
| IV     | rrrrr0000110dddd | -                | SLD.BU   | disp4 [ep], reg2     |
|        | rrrrr0000111dddd | _                | SLD.HU   | disp5 [ep], reg2     |
|        | rrrrr0110dddddd  | -                | SLD.B    | disp7 [ep], reg2     |
|        | rrrrr0111ddddddd | _                | SST.B    | reg2, disp7 [ep]     |
|        | rrrrr1000ddddddd | -                | SLD.H    | disp8 [ep], reg2     |
|        | rrrrr1001dddddd  | _                | SST.H    | reg2, disp8 [ep]     |
|        | rrrrr1010dddddd0 | -                | SLD.W    | disp8 [ep], reg2     |
|        | rrrrr1010dddddd1 | _                | SST.W    | reg2, disp8 [ep]     |
| ٧      | rrrrr11110dddddd | dddddddddddd     | JARL     | disp22, reg2         |
|        | 0000011110dddddd | dddddddddddd     | JR       | disp22               |
| VI     | rrrr110000RRRRR  | iiiiiiiiiiiiiii  | ADDI     | imm16, reg1, reg2    |
|        | rrrr110001RRRRR  | iiiiiiiiiiiiiii  | MOVEA    | imm16, reg1, reg2    |
|        | rrrr110010RRRRR  | iiiiiiiiiiiiiii  | MOVHI    | imm16, reg1, reg2    |
|        | rrrr110011RRRRR  | iiiiiiiiiiiiiii  | SATSUBI  | imm16, reg1, reg2    |
|        | 00000110001RRRRR | Note MOV         |          | imm32, reg1          |
|        | rrrr110100RRRRR  | iiiiiiiiiiiiiii  | ORI      | imm16, reg1, reg2    |
|        | rrrr110101RRRRR  | iiiiiiiiiiiiiii  | XORI     | imm16, reg1, reg2    |
|        | rrrr110110RRRRR  | iiiiiiiiiiiiiii  | ANDI     | imm16, reg1, reg2    |
|        | rrrr110111RRRRR  | iiiiiiiiiiiiiiii | MULHI    | imm16, reg1, reg2    |
| VII    | rrrr111000RRRRR  | ddddddddddddd    | LD.B     | disp16 [reg1], reg2  |
|        | rrrr111001RRRRR  | dddddddddddd     | LD.H     | disp16 [reg1], reg2  |
|        | rrrr111001RRRRR  | dddddddddddd     | LD.W     | disp16 [reg1], reg2  |
|        | rrrr111010RRRRR  | ddddddddddddd    | ST.B     | reg2, disp16 [reg1]  |
|        | rrrr111011RRRRR  | dddddddddddd     | ST.H     | reg2, disp16 [reg1]  |
|        | rrrr111011RRRRR  | dddddddddddd     | ST.W     | reg2, disp16 [reg1]  |
|        | rrrr11110bRRRRR  | dddddddddddd     | LD.BU    | disp16 [reg1], reg2  |
|        | rrrr111111RRRRR  | dddddddddddd     | LD.HU    | disp16 [reg1], reg2  |
| VIII   | 00bbb111110RRRRR | ddddddddddddd    | SET1     | bit#3, disp16 [reg1] |
|        | 01bbb111110RRRRR | ddddddddddddd    | NOT1     | bit#3, disp16 [reg1] |
|        | 10bbb111110RRRRR | ddddddddddddd    | CLR1     | bit#3, disp16 [reg1] |
|        | 11bbb111110RRRRR | ddddddddddddd    | TST1     | bit#3, disp16 [reg1] |

#### Table A-2. Instruction List (in Format Order) (2/3)

Note 32-bit immediate data. The higher 32 bits (bits 16 to 47) are as follows.

| 31 16           | 47 32            |
|-----------------|------------------|
| iiiiiiiiiiiiiii | IIIIIIIIIIIIIIII |

| Format | Орс              | code                | Mnemonic | Operand                |
|--------|------------------|---------------------|----------|------------------------|
|        | 15 0             | 31 16               |          |                        |
| IX     | rrrrr1111110cccc | 0000000000000000000 | SETF     | cccc, reg2             |
|        | rrrrr111111RRRRR | 0000000000100000    | LDSR     | reg2, regID            |
|        | rrrrr111111RRRRR | 0000000001000000    | STSR     | regID, reg2            |
|        | rrrr111111RRRRR  | 0000000010000000    | SHR      | reg1, reg2             |
|        | rrrrr111111RRRRR | 0000000010100000    | SAR      | reg1, reg2             |
|        | rrrr111111RRRRR  | 0000000011000000    | SHL      | reg1, reg2             |
|        | rrrr111111RRRRR  | 0000000011100000    | SET1     | reg2, [reg1]           |
|        | rrrr111111RRRRR  | 0000000011100010    | NOT1     | reg2, [reg1]           |
|        | rrrrr111111RRRRR | 0000000011100100    | CLR1     | reg2, [reg1]           |
|        | rrrr111111RRRRR  | 0000000011100110    | TST1     | reg2, [reg1]           |
|        | rrrrr1111110cccc | 0000010000000000    | SASF     | cccc, reg2             |
| Х      | 00000111111iiii  | 0000000100000000    | TRAP     | vector                 |
|        | 0000011111100000 | 0000000100100000    | HALT     | -                      |
|        | 0000011111100000 | 0000000101000000    | RETI     | -                      |
|        | 0000011111100000 | 0000000101000100    | CTRET    | -                      |
|        | 0000011111100000 | 0000000101000110    | DBRET    | -                      |
|        | 0000011111100000 | 0000000101100000    | DI       | -                      |
|        | 1000011111100000 | 0000000101100000    | EI       | -                      |
| XI     | rrrrr111111RRRRR | wwwww01000100000    | MUL      | reg1, reg2, reg3       |
|        | rrrr111111RRRRR  | wwwww01000100010    | MULU     | reg1, reg2, reg3       |
|        | rrrr111111RRRRR  | wwwww01010000000    | DIVH     | reg1, reg2, reg3       |
|        | rrrr111111RRRRR  | wwwww0101000010     | DIVHU    | reg1, reg2, reg3       |
|        | rrrr111111RRRRR  | wwwww01011000000    | DIV      | reg1, reg2, reg3       |
|        | rrrr111111RRRRR  | wwwww01011000010    | DIVU     | reg1, reg2, reg3       |
|        | rrrr111111RRRRR  | wwwww011001cccc0    | CMOV     | cccc, reg1, reg2, reg3 |
| XII    | rrrrr111111iiii  | wwwww01001IIII00    | MUL      | imm9, reg2, reg3       |
|        | rrrrr111111iiii  | wwwww01001IIII0     | MULU     | imm9, reg2, reg3       |
|        | rrrrr111111iiii  | wwwww011000cccc0    | CMOV     | cccc, imm5, reg2, reg3 |
|        | rrrr11111100000  | wwwww01101000000    | BSW      | reg2, reg3             |
|        | rrrr11111100000  | wwwww0110100010     | BSH      | reg2, reg3             |
|        | rrrr11111100000  | wwwww01101000100    | HSW      | reg2, reg3             |
| XIII   | 0000011001iiiiL  | LLLLLLLLLRRRRR      | DISPOSE  | imm5, list12, [reg1]   |
|        | 0000011001iiiiL  | LLLLLLLLL00000      | DISPOSE  | imm5, list12           |
|        | 0000011110iiiiL  | LLLLLLLLL00001      | PREPARE  | list12, imm5           |
|        | 0000011110iiiiL  | LLLLLLLLLff011      | PREPARE  | list12, imm5, sp/imm   |

### Table A-2. Instruction List (in Format Order) (3/3)

#### APPENDIX B INSTRUCTION OPCODE MAP

This chapter shows the opcode map for the instruction code shown below.

#### (1) 16-bit format instruction



#### (2) 32-bit format instruction



#### Remark Operand convention

| Symbol | Meaning                                                                                                             |
|--------|---------------------------------------------------------------------------------------------------------------------|
| R      | reg1: General-purpose register (used as source register)                                                            |
| r      | reg2: General-purpose register (mainly used as destination register. Some are also used as source registers.)       |
| w      | reg3: General-purpose register (mainly used as remainder of division results or higher 32 bits of multiply results) |
| bit#3  | 3-bit data for bit number specification                                                                             |
| imm×   | ×-bit immediate data                                                                                                |
| disp×  | ×-bit displacement data                                                                                             |
| cccc   | 4-bit data condition code specification                                                                             |

#### [a] Opcode

| Bit | Bit | Bit | Bit |                                                                      | Bits                                             | 6, 5                                                                      |                                                                                            | Format                |
|-----|-----|-----|-----|----------------------------------------------------------------------|--------------------------------------------------|---------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|-----------------------|
| 10  | 9   | 8   | 7   | 0,0                                                                  | 0,1                                              | 1,0                                                                       | 1,1                                                                                        |                       |
| 0   | 0   | 0   | 0   | MOV R, r<br>NOP <sup>Note 1</sup>                                    | NOT                                              | DIVH<br>SWITCH <sup>Note 2</sup><br>DBTRAP<br>Undefined <sup>Note 3</sup> | JMP <sup>Note 4</sup><br>SLD.BU <sup>Note 5</sup><br>SLD.HU <sup>Note 6</sup>              | I, IV                 |
| 0   | 0   | 0   | 1   | SATSUBR<br>ZXB <sup>Note 4</sup>                                     | SATSUB<br>SXB <sup>Note 4</sup>                  | SATADD R, r<br>ZXH <sup>Note 4</sup>                                      | MULH<br>SXH <sup>Note 4</sup>                                                              | 1                     |
| 0   | 0   | 1   | 0   | OR                                                                   | XOR                                              | AND                                                                       | TST                                                                                        |                       |
| 0   | 0   | 1   | 1   | SUBR                                                                 | SUB                                              | ADD R, r                                                                  | CMP R, r                                                                                   |                       |
| 0   | 1   | 0   | 0   | MOV imm5, r<br>CALLT <sup>Note 4</sup>                               | SATADD imm5, r                                   | ADD imm5, r                                                               | CMP imm5, r                                                                                | II                    |
| 0   | 1   | 0   | 1   | SHR imm5, r                                                          | SAR imm5, r                                      | SHL imm5, r                                                               | MULH imm5, r<br>Undefined <sup>Note 4</sup>                                                |                       |
| 0   | 1   | 1   | 0   | SLD.B                                                                |                                                  |                                                                           |                                                                                            | IV                    |
| 0   | 1   | 1   | 1   | SST.B                                                                |                                                  |                                                                           |                                                                                            |                       |
| 1   | 0   | 0   | 0   | SLD.H                                                                |                                                  |                                                                           |                                                                                            |                       |
| 1   | 0   | 0   | 1   | SST.H                                                                |                                                  |                                                                           |                                                                                            |                       |
| 1   | 0   | 1   | 0   | SLD.W <sup>Note 7</sup><br>SST.W <sup>Note 7</sup>                   |                                                  |                                                                           |                                                                                            |                       |
| 1   | 0   | 1   | 1   | Bcond                                                                |                                                  |                                                                           |                                                                                            | III                   |
| 1   | 1   | 0   | 0   | ADDI                                                                 | MOVEA<br>MOV imm32, R <sup>Note 4</sup>          | MOVHI<br>DISPOSE <sup>Note 4</sup>                                        | SATSUBI                                                                                    | VI, XIII              |
| 1   | 1   | 0   | 1   | ORI                                                                  | XORI                                             | ANDI                                                                      | MULHI<br>Undefined <sup>Note 4</sup>                                                       | VI                    |
| 1   | 1   | 1   | 0   | LD.B                                                                 | LD.H <sup>Note 8</sup><br>LD.W <sup>Note 8</sup> | ST.B                                                                      | ST.H <sup>Note 8</sup><br>ST.W <sup>Note 8</sup>                                           | VII                   |
| 1   | 1   | 1   | 1   | JR<br>JARL<br>LD.BU <sup>Note 10</sup><br>PREPARE <sup>Note 11</sup> |                                                  | Bit manipulation 1 <sup>Note 9</sup>                                      | LD.HU <sup>Note 10</sup><br>Undefined <sup>Note 11</sup><br>Expansion 1 <sup>Note 12</sup> | V, VII,<br>VIII, XIII |

**Notes 1.** If R (reg1) = r0 and r (reg2) = r0 (instruction without reg1 and reg2)

**2.** If R (reg1)  $\neq$  r0 and r (reg2) = r0 (instruction with reg1 and without reg2)

**3.** If R (reg1) = r0 and r (reg2)  $\neq$  r0 (instruction without reg1 and with reg2)

**4.** If r (reg2) = r0 (instruction without reg2)

5. If bit 4 = 0 and r (reg2)  $\neq$  r0 (instruction with reg2)

**6.** If bit 4 = 1 and r (reg2)  $\neq$  r0 (instruction with reg2)

7. See [b]

8. See [c]

9. See [d]

**10.** If bit 16 = 1 and r (reg2)  $\neq$  r0 (instruction with reg2)

**11.** If bit 16 = 1 and r (reg2) = r0 (instruction without reg2)

12. See [e]

#### [b] Short format load/store instruction (displacement/sub-opcode)

| Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 0 |   |       |  |  |
|--------|-------|-------|-------|-------|---|-------|--|--|
|        |       |       |       |       | 0 | 1     |  |  |
| 0      | 1     | 1     | 0     | SLD.B |   |       |  |  |
| 0      | 1     | 1     | 1     | SST.B |   |       |  |  |
| 1      | 0     | 0     | 0     | SLD.H |   |       |  |  |
| 1      | 0     | 0     | 1     | SST.H |   |       |  |  |
| 1      | 0     | 1     | 0     | SLD.W |   | SST.W |  |  |

#### [c] Load/store instruction (displacement/sub-opcode)

| Bit 6 | Bit 5 | Bit 16 |      |  |  |  |
|-------|-------|--------|------|--|--|--|
|       |       | 0      | 1    |  |  |  |
| 0     | 0     | LD.B   |      |  |  |  |
| 0     | 1     | LD.H   | LD.W |  |  |  |
| 1     | 0     | ST.B   |      |  |  |  |
| 1     | 1     | ST.H   | ST.W |  |  |  |

#### [d] Bit manipulation instruction 1 (sub-opcode)

| Bit 15 | Bit                    | 14                     |
|--------|------------------------|------------------------|
|        | 0                      | 1                      |
| 0      | SET1 bit#3, disp16 [R] | NOT1 bit#3, disp16 [R] |
| 1      | CLR1 bit#3, disp16 [R] | TST1 bit#3, disp16 [R] |

### [e] Expansion 1 (sub-opcode)

| Bit 26 | Bit 25 | Bit 24 | Bit 23 |                                 | Bits                                          | 22, 21                                                                                    |                                                           | Format      |
|--------|--------|--------|--------|---------------------------------|-----------------------------------------------|-------------------------------------------------------------------------------------------|-----------------------------------------------------------|-------------|
|        |        |        |        | 0,0                             | 0,1                                           | 1,0                                                                                       | 1,1                                                       |             |
| 0      | 0      | 0      | 0      | SETF                            | LDSR                                          | STSR                                                                                      | Undefined                                                 | IX          |
| 0      | 0      | 0      | 1      | SHR                             | SAR                                           | SHL                                                                                       | Bit manipulation 2 <sup>Note 1</sup>                      |             |
| 0      | 0      | 1      | 0      | TRAP                            | HALT                                          | RETI <sup>Note 2</sup><br>CTRET <sup>Note 2</sup><br>DBRET <sup>Note 2</sup><br>Undefined | El <sup>Note 3</sup><br>DI <sup>Note 3</sup><br>Undefined | x           |
| 0      | 0      | 1      | 1      | Undefined                       |                                               | Undefined                                                                                 |                                                           | _           |
| 0      | 1      | 0      | 0      | SASF                            | MUL R, r, w<br>MULU R, r, w <sup>Note 4</sup> | MUL imm9, r, w<br>MULU imm9, r, w <sup>Note 4</sup>                                       |                                                           | IX, XI, XII |
| 0      | 1      | 0      | 1      | DIVH<br>DIVHU <sup>Note 4</sup> |                                               | DIV<br>DIVU <sup>Note 4</sup>                                                             |                                                           | XI          |
| 0      | 1      | 1      | 0      | CMOV<br>cccc, imm5, r, w        | CMOV<br>cccc, R, r, w                         | BSW <sup>Note 5</sup><br>BSH <sup>Note 5</sup><br>HSW <sup>Note 5</sup>                   | Undefined                                                 | XI, XII     |
| 0      | 1      | 1      | 1      | Illegal instruction             |                                               |                                                                                           | •                                                         | _           |
| 1      | х      | х      | х      |                                 |                                               |                                                                                           |                                                           |             |

- Notes 1. See [f]
  - 2. See [g]
  - 3. See [h]
  - **4.** If bit 17 = 1
  - 5. See [i]

#### [f] Bit manipulation instruction 2 (sub-opcode)

| Bit 18 | Bit 17      |             |  |  |  |
|--------|-------------|-------------|--|--|--|
|        | 0           | 1           |  |  |  |
| 0      | SET1 r, [R] | NOT1 r, [R] |  |  |  |
| 1      | CLR1 r, [R] | TST1 r, [R] |  |  |  |

#### [g] Return instruction (sub-opcode)

| Bit 18 | Bit 17 |           |  |
|--------|--------|-----------|--|
|        | 0      | 1         |  |
| 0      | RETI   | Undefined |  |
| 1      | CTRET  | DBRET     |  |

### [h] PSW operation instruction (sub-opcode)

| Bit 15 | Bit 14 | Bits 13, 12, 11 |              |       |       |       |       |       |       |
|--------|--------|-----------------|--------------|-------|-------|-------|-------|-------|-------|
|        |        | 0,0,0           | 0,0,1        | 0,1,0 | 0,1,1 | 1,0,0 | 1,0,1 | 1,1,0 | 1,1,1 |
| 0      | 0      | DI              | Undefined    |       |       |       |       |       |       |
| 0      | 1      | Undefined       | Undefined    |       |       |       |       |       |       |
| 1      | 0      | EI              | EI Undefined |       |       |       |       |       |       |
| 1      | 1      | Undefined       |              |       |       |       |       |       |       |

## [i] Endian conversion instruction (sub-opcode)

| Bit 18 | Bit 17 |           |
|--------|--------|-----------|
|        | 0      | 1         |
| 0      | BSW    | BSH       |
| 1      | HSW    | Undefined |

### APPENDIX C DIFFERENCES IN ARCHITECTURE OF V850 CPU AND V850E1 CPU

|                     | Item                         | V850ES CPU | V850E1 CPU               | V850 CPU     |
|---------------------|------------------------------|------------|--------------------------|--------------|
| Instructions        | BSH reg2, reg3               | Provided   |                          | Not provided |
| (including operand) | BSW reg2, reg3               |            |                          | -            |
|                     | CALLT imm6                   |            |                          |              |
|                     | CLR1 reg2, [reg1]            |            |                          |              |
|                     | CMOV cccc, imm5, reg2, reg3  |            |                          |              |
|                     | CMOV cccc, reg1, reg2, reg3  |            |                          |              |
|                     | CTRET                        |            |                          |              |
|                     | DBRET                        | Provided   | Provided <sup>Note</sup> |              |
|                     | DBTRAP                       |            |                          |              |
|                     | DISPOSE imm5, list12         | Provided   |                          |              |
|                     | DISPOSE imm5, list12 [reg1]  |            |                          |              |
|                     | DIV reg1, reg2, reg3         |            |                          |              |
|                     | DIVH reg1, reg2, reg3        |            |                          |              |
|                     | DIVHU reg1, reg2, reg3       |            |                          |              |
|                     | DIVU reg1, reg2, reg3        |            |                          |              |
|                     | HSW reg2, reg3               |            |                          |              |
|                     | LD.BU disp16 [reg1], reg2    |            |                          |              |
|                     | LD.HU disp16 [reg1], reg2    |            |                          |              |
|                     | MOV imm32, reg1              |            |                          |              |
|                     | MUL imm9, reg2, reg3         |            |                          |              |
|                     | MUL reg1, reg2, reg3         |            |                          |              |
|                     | MULU reg1, reg2, reg3        |            |                          |              |
|                     | MULU imm9, reg2, reg3        |            |                          |              |
|                     | NOT1 reg2, [reg1]            |            |                          |              |
|                     | PREPARE list12, imm5         |            |                          |              |
|                     | PREPARE list12, imm5, sp/imm |            |                          |              |
|                     | SASF cccc, reg2              |            |                          |              |
|                     | SET1 reg2, [reg1]            |            |                          |              |
|                     | SLD.BU disp4 [ep], reg2      |            |                          |              |
|                     | SLD.HU disp5 [ep], reg2      |            |                          |              |
|                     | SWITCH reg1                  |            |                          |              |
|                     | SXB reg1                     |            |                          |              |
|                     | SXH reg1                     |            |                          |              |
|                     | TST1 reg2, [reg1]            |            |                          |              |
|                     | ZXB reg1                     |            |                          |              |
|                     | ZXH reg1                     |            |                          |              |

Note Not supported in the NB85E and NB85ET

|                                             | Item                                                        | V850ES CPU                                                              | V850E1 CPU                                   | V850 CPU                                          |  |
|---------------------------------------------|-------------------------------------------------------------|-------------------------------------------------------------------------|----------------------------------------------|---------------------------------------------------|--|
| Instruction format                          | Format IV                                                   |                                                                         | structions differs be<br>s and the V850 CPL  |                                                   |  |
|                                             | Format XI                                                   | Provided                                                                |                                              | Not provided                                      |  |
|                                             | Format XII                                                  |                                                                         |                                              |                                                   |  |
|                                             | Format XIII                                                 |                                                                         |                                              |                                                   |  |
| Number of instruction cloo<br>instructions) | sks executed (except MUL, MULU                              |                                                                         | differs partially betw<br>s and the V850 CPL |                                                   |  |
|                                             | MUL, MULU instructions                                      | 1/4/5 clocks                                                            | 1/2/2 clocks                                 | Not provided                                      |  |
| Program space                               |                                                             | 64 MB linear<br>(usable area: 16<br>MB + 60 KB)                         | 64 MB linear                                 | 16 MB linear                                      |  |
| Valid bits of program cour                  | nter (PC)                                                   | Lower 26 bits                                                           |                                              | Lower 24 bits                                     |  |
| System register                             | CALLT execution status saving registers (CTPC, CTPSW)       | Provided                                                                |                                              | Not provided                                      |  |
|                                             | Exception/debug trap status saving registers (DBPC, DBPSW)  |                                                                         |                                              |                                                   |  |
|                                             | CALLT base pointer (CTBP)                                   |                                                                         |                                              | _                                                 |  |
|                                             | Debug interface register (DIR)                              | Not provided                                                            | Provided <sup>Note 1</sup>                   |                                                   |  |
|                                             | Breakpoint control registers 0 and 1 (BPC0, BPC1)           |                                                                         |                                              |                                                   |  |
|                                             | Program ID register (ASID)                                  |                                                                         |                                              |                                                   |  |
|                                             | Breakpoint address setting registers 0 and 1 (BPAV0, BPAV1) |                                                                         |                                              |                                                   |  |
|                                             | Breakpoint address mask registers 0 and 1 (BPAM0, BPAM1)    |                                                                         |                                              |                                                   |  |
|                                             | Breakpoint data setting registers 0 and 1 (BPDV0, BPDV1)    |                                                                         |                                              |                                                   |  |
|                                             | Breakpoint data mask registers 0 and 1 (BPDM0, BPDM1)       |                                                                         |                                              |                                                   |  |
|                                             | Exception trap status saving registers                      | DBPC, DBPSW                                                             |                                              | EIPC, EIPSW                                       |  |
| Illegal instruction code                    | · · · · · · · · · · · · · · · · · · ·                       | Instruction code areas differ.                                          |                                              | ·                                                 |  |
| Misaligned access enable                    | /disable setting                                            | Fixed to enable                                                         | Can be set<br>depending on<br>product        | Cannot be set.<br>(misaligned<br>access disabled) |  |
| Non-maskable interrupt                      | Input                                                       | 3 <sup>Note 2</sup>                                                     |                                              | 1                                                 |  |
| (NMI)                                       | Exception code                                              | 0010H, 0020H <sup>Note 2</sup> , 0030H <sup>Note 2</sup>                |                                              | 0010H                                             |  |
|                                             | Handler address                                             | 00000010H, 00000020H <sup>Note 2</sup> ,<br>00000030H <sup>Note 2</sup> |                                              | 00000010H                                         |  |
| Debug trap                                  | 1                                                           | Provided                                                                | Provided <sup>Note 3</sup>                   | Not provided                                      |  |

Notes 1. Used only for the NU85E and NU85ET

- 2. Some products do not have this function.
- 3. Not supported in the NB85E and NB85ET

(3/3)

| * |          | Item                                                                                                                                                                                                           | V850ES CPU | V850E1 CPU | V850 CPU        |
|---|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|------------|-----------------|
|   | Pipeline | Word data multiply instruction                                                                                                                                                                                 | Note 1     | Note 1     | No instructions |
|   |          | <ul> <li>Arithmetic operation instruction other<br/>than word data multiply instruction</li> <li>Branch instruction</li> <li>Bit manipulation instruction</li> <li>Special instruction (TRAP, RETI)</li> </ul> | Not        | te 2       | Note 2          |

Notes 1. The pipeline flow differs between the V850ES CPU core and the V850E1 CPU core. For details, refer to CHAPTER 8 PIPELINE and V850E1 Architecture User's Manual (U14559E).

 The pipeline flow differs between the V850ES and V850E1 CPU cores and the V850 CPU core. For details, refer to CHAPTER 8 PIPELINE, V850E1 Architecture User's Manual (U14559E), and V850 Series Architecture User's Manual (U10243E).

#### APPENDIX D INSTRUCTIONS ADDED FOR V850ES CPU COMPARED WITH V850 CPU

Compared with the instruction codes of the V850 CPU, the instruction codes of the V850ES CPU are upwardly compatible at the object code level. In the case of the V850ES CPU, instructions that even if executed have no meaning in the case of the V850 CPU (mainly instructions performing write to the r0 register) are extended as additional instructions.

The following table shows the V850 CPU instructions corresponding to the instruction codes added in the V850ES CPU. See the table when switching from products that incorporate the V850 CPU to products that incorporate the V850ES CPU.

Since the V850ES CPU is compatible with all the instruction codes of the V850E1 CPU, these products are replaced easily.

#### Table D-1. Instructions Added to V850ES CPU and V850 CPU Instructions with Same Instruction Code (1/2)

| Instructions Added in V850ES CPU | V850 CPU Instructions with Same Instruction<br>Code as V850ES CPU |
|----------------------------------|-------------------------------------------------------------------|
| CALLT imm6                       | MOV imm5, r0 or SATADD imm5, r0                                   |
| DISPOSE imm5, list12             | MOVHI imm16, reg1, r0 or SATSUBI imm16, reg1, r0                  |
| DISPOSE imm5, list12 [reg1]      | MOVHI imm16, reg1, r0 or SATSUBI imm16, reg1, r0                  |
| MOV imm32, reg1                  | MOVEA imm16, reg1, r0                                             |
| SWITCH reg1                      | DIVH reg1, r0                                                     |
| SXB reg1                         | SATSUB reg1, r0                                                   |
| SXH reg1                         | MULH reg1, r0                                                     |
| ZXB reg1                         | SATSUBR reg1, r0                                                  |
| ZXH reg1                         | SATADD reg1, r0                                                   |
| (RFU)                            | MULH imm5, r0                                                     |
| (RFU)                            | MULHI imm16, reg1, r0                                             |
| BSH reg2, reg3                   | Illegal instruction                                               |
| BSW reg2, reg3                   |                                                                   |
| CMOV cccc, imm5, reg2, reg3      |                                                                   |
| CMOV cccc, reg1, reg2, reg3      |                                                                   |
| CTRET                            |                                                                   |
| DIV reg1, reg2, reg3             |                                                                   |
| DIVH reg1, reg2, reg3            |                                                                   |
| DIVHU reg1, reg2, reg3           |                                                                   |
| DIVU reg1, reg2, reg3            |                                                                   |
| HSW reg2, reg3                   |                                                                   |
| MUL imm9, reg2, reg3             |                                                                   |
| MUL reg1, reg2, reg3             |                                                                   |
| MULU reg1, reg2, reg3            |                                                                   |
| MULU imm9, reg2, reg3            |                                                                   |
| SASF cccc, reg2                  |                                                                   |

### Table D-1. Instructions Added to V850ES CPU and V850 CPU Instructions with Same Instruction Code (2/2)

| Instructions Added in V850ES CPU | V850 CPU Instructions with Same Instruction<br>Code as V850ES CPU |
|----------------------------------|-------------------------------------------------------------------|
| CLR1 reg2, [reg1]                | Undefined                                                         |
| DBRET                            |                                                                   |
| DBTRAP                           |                                                                   |
| LD.BU disp16 [reg1], reg2        |                                                                   |
| LD.HU disp16 [reg1], reg2        |                                                                   |
| NOT1 reg2, [reg1]                |                                                                   |
| PREPARE list12, imm5             |                                                                   |
| PREPARE list12, imm5, sp/imm     |                                                                   |
| SET1 reg2, [reg1]                |                                                                   |
| SLD.BU disp4 [ep], reg2          |                                                                   |
| SLD.HU disp5 [ep], reg2          |                                                                   |
| TST1 reg2, [reg1]                |                                                                   |

### APPENDIX E INDEX

## [Numeral]

| 16-bit format instruction            |     |
|--------------------------------------|-----|
| 16-bit load/store instruction format |     |
| 2-clock branch                       | 148 |
| 3-operand instruction format         |     |
| 32-bit format instruction            |     |
| 32-bit load/store instruction format |     |

## [A]

| ADD                                            | 45  |
|------------------------------------------------|-----|
| ADDI                                           | 46  |
| Additional items related to pipeline           | 166 |
| Address space                                  | 29  |
| Addressing mode                                | 31  |
| Alignment hazard                               | 162 |
| AND                                            | 47  |
| ANDI                                           |     |
| Arithmetic operation instructions              | 40  |
| Arithmetic operation instructions (pipeline) . | 153 |

## [B]

| Based addressing                         |        |
|------------------------------------------|--------|
| Bcond                                    |        |
| Bit                                      | 27, 28 |
| Bit addressing                           |        |
| Bit manipulation instruction format      |        |
| Bit manipulation instructions            | 41     |
| Bit manipulation instructions (pipeline) | 156    |
| BR instruction (pipeline)                | 155    |
| Branch instructions                      | 41     |
| Branch instructions (pipeline)           | 154    |
| BSH                                      | 51     |
| BSW                                      |        |
| Byte                                     | 27     |

## [C]

| CALLT                                 | 53  |
|---------------------------------------|-----|
| CALLT base pointer                    | 25  |
| CALLT caller status saving registers  | 24  |
| CALLT instruction (pipeline)          | 156 |
| Cautions when creating programs       | 165 |
| CLR1                                  | 54  |
| CLR1 instruction (pipeline)           | 156 |
| CMOV                                  | 55  |
| CMP                                   | 56  |
| Conditional branch instruction format | 36  |
| CTBP                                  | 25  |
| CTPC                                  | 24  |

| CTPSW                        | . 24 |
|------------------------------|------|
| CTRET                        | . 57 |
| CTRET instruction (pipeline) | 157  |

## [D]

| Data alignment                         |     |
|----------------------------------------|-----|
| Data format                            |     |
| Data representation                    |     |
| Data type                              |     |
| DBPC                                   |     |
| DBPSW                                  |     |
| DBRET                                  |     |
| DBRET instruction (pipeline)           |     |
| DBTRAP                                 |     |
| DBTRAP instruction (pipeline)          |     |
| Debug function instructions            |     |
| Debug function instructions (pipeline) | 161 |
| Debug trap                             | 141 |
| DI                                     | 60  |
| DI instruction (pipeline)              | 157 |
| DISPOSE                                | 61  |
| DISPOSE instruction (pipeline)         | 158 |
| DIV                                    |     |
| DIVH                                   |     |
| DIVHU                                  |     |
| Divide instructions (pipeline)         |     |
| DIVU                                   |     |
|                                        |     |

## [E]

| ECR                                          | 22 |
|----------------------------------------------|----|
| Efficient pipeline processing 14             | 19 |
| El                                           | 38 |
| EIPC                                         | 21 |
| EIPSW                                        | 21 |
| El instruction (pipeline) 15                 | 57 |
| Exception cause register                     | 22 |
| Exception/debug trap status saving registers | 25 |
| Exception processing13                       | 39 |
| Exception trap14                             | 40 |
| Extended instruction format 1                | 37 |
| Extended instruction format 2                | 38 |
| Extended instruction format 3                | 38 |
| Extended instruction format 4                | 38 |

## [F]

| 22 |
|----|
| 22 |
| 35 |
| 35 |
|    |

| Format III  | 36    |
|-------------|-------|
| Format IV   | 36    |
| Format IX   | 37    |
| Format V    |       |
| Format VI   | 37    |
| Format VII  | 37    |
| Format VIII | ••••• |
| Format X    |       |
| Format XI   |       |
| Format XII  |       |
| Format XIII |       |
|             |       |

## [G]

| General-purpose registers | 19 |
|---------------------------|----|
|---------------------------|----|

## [H]

| Halfword                    | 27 |
|-----------------------------|----|
| HALT                        | 69 |
| HALT instruction (pipeline) |    |
| Harvard architecture        |    |
| HSW                         | 70 |
|                             |    |

# [I]

| imm-reg instruction format        | 35 |
|-----------------------------------|----|
| Immediate addressing              | 33 |
| Instruction address               | 31 |
| Instruction format                | 35 |
| Instruction opcode map            |    |
| Instruction set                   | 43 |
| Integer                           | 28 |
| Internal configuration            | 17 |
| Interrupt servicing               |    |
| Interrupt status saving registers | 21 |

# [J]

| JARL                       | 71  |
|----------------------------|-----|
| JMP                        | 72  |
| JMP instruction (pipeline) | 155 |
| JR                         | 73  |
| Jump instruction format    | 36  |

## [L]

| LD instructions             |     |
|-----------------------------|-----|
| LD instructions (pipeline)  | 150 |
| LD.B                        | 74  |
| LD.BU                       | 75  |
| LD.H                        | 76  |
| LD.HU                       | 77  |
| LD.W                        | 78  |
| LDSR                        | 79  |
| LDSR instruction (pipeline) | 158 |

| 39  |
|-----|
| 150 |
| 40  |
| 154 |
|     |

## [M]

| Maskable interrupt               |     |
|----------------------------------|-----|
| Memory map                       |     |
| MOV                              | 80  |
| MOVEA                            | 81  |
| Move word instruction (pipeline) | 153 |
| MOVHI                            | 82  |
| MUL                              | 83  |
| MULH                             |     |
| MULHI                            | 85  |
| Multiply instructions            | 39  |
| Multiply instructions (pipeline) | 151 |
| MULU                             | 86  |

## [N]

| NMI status saving registers |     |
|-----------------------------|-----|
| Non-blocking load/store     | 147 |
| Non-maskable interrupt      | 138 |
| NOP                         | 87  |
| NOP instruction (pipeline)  | 159 |
| NOT                         | 88  |
| NOT1                        | 89  |
| NOT1 instruction (pipeline) | 156 |

# [**O**]

| Operand address |    |
|-----------------|----|
| OR              | 90 |
| ORI             | 91 |

## [P]

| PC                                                 |
|----------------------------------------------------|
| Pipeline145                                        |
| Pipeline disorder                                  |
| Pipeline flow during execution of instructions 150 |
| PREPARE                                            |
| PREPARE instruction (pipeline)159                  |
| Program counter                                    |
| Program registers                                  |
| Program status word23                              |
| PSW23                                              |

## [R]

| r0 to r31                               | 19 |
|-----------------------------------------|----|
| reg-reg instruction format              | 35 |
| Register addressing                     | 33 |
| Register addressing (register indirect) | 32 |

| Register set                                    | 18 |
|-------------------------------------------------|----|
| Register status after reset14                   | 14 |
| Relative addressing (PC relative)               | 31 |
| Reset14                                         | 14 |
| Restoring from exception trap and debug trap 14 | 43 |
| Restoring from interrupt/exception processing14 | 42 |
| RETI                                            | 94 |
| RETI instruction (pipeline)15                   | 59 |
|                                                 |    |

## [S]

| SAR                                         | 96  |
|---------------------------------------------|-----|
| SASF                                        | 97  |
| SATADD                                      | 98  |
| SATSUB                                      | 99  |
| SATSUBI                                     | 100 |
| SATSUBR                                     | 101 |
| Saturated operation instructions            | 40  |
| Saturated operation instructions (pipeline) | 154 |
| SET1                                        | 102 |
| SET1 instruction (pipeline)                 | 156 |
| SETF                                        | 103 |
| SHL                                         | 105 |
| Short path                                  | 167 |
| SHR                                         | 106 |
| SLD.B                                       | 107 |
| SLD.BU                                      | 108 |
| SLD.H                                       | 109 |
| SLD.HU                                      | 110 |
| SLD.W                                       | 111 |
| SLD instructions                            | 39  |
| SLD instructions (pipeline)                 | 150 |
| Software exception                          |     |
| Special instructions                        | 41  |
| Special instructions (pipeline)             | 156 |
| SST.B                                       | 112 |
| SST.H                                       | 113 |
| SST.W                                       | 114 |
| SST instructions                            | 39  |
| ST.B                                        | 115 |
| ST.H                                        | 116 |
| ST.W                                        | 117 |
| ST instructions                             |     |
| Stack manipulation instruction format 1     | 38  |
| Starting up                                 | 144 |
| Store instructions                          | 39  |
| Store instructions (pipeline)               | 151 |
| STSR                                        |     |
| STSR instruction (pipeline)                 | 158 |
| SUB                                         | 119 |
| SUBR                                        | 120 |
| SWITCH                                      |     |
| SWITCH instruction (pipeline)               | 160 |
| SXB                                         | 122 |
| SXH                                         | 123 |
| System registers                            | 20  |

# [T]

| TRAP                        | 124 |
|-----------------------------|-----|
| TRAP instruction (pipeline) | 160 |
| TST                         | 125 |
| TST1                        | 126 |
| TST1 instruction (pipeline) | 156 |

## [U]

| Unconditional branch instructions |      |  |  |  |
|-----------------------------------|------|--|--|--|
| Unsigned integer                  | . 28 |  |  |  |

## [W]

| Word | <br>26 |
|------|--------|
|      |        |

## [X]

| XOR  | 127 |
|------|-----|
| XORI | 128 |

## [Z]

| ZXB | 129 |
|-----|-----|
| ZXH | 130 |

#### APPENDIX F REVISION HISTORY

A history of the revisions up to this edition is shown below. "Applied to:" indicates the chapters to which the revision was applied.

| Edition | Revisions from Previous Edition                                                                                 | Applied to:                                                             |  |
|---------|-----------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|--|
| 2nd     | Modification of description of V850ES CPU core in Figure 1-1 V850 Series<br>CPU Development                     | CHAPTER 1 GENERAL                                                       |  |
|         | Addition of description of Caution in 5.3 Instruction Set MUL                                                   | CHAPTER 5 INSTRUCTION                                                   |  |
|         | Addition of description of Caution in 5.3 Instruction Set MULU                                                  |                                                                         |  |
|         | Modification of description of pipeline in APPENDIX C DIFFERENCES IN<br>ARCHITECTURE OF V850 CPU AND V850E1 CPU | APPENDIX C DIFFERENCES<br>IN ARCHITECTURE OF V850<br>CPU AND V850E1 CPU |  |
|         | Addition of APPENDIX F REVISION HISTORY                                                                         | APPENDIX F REVISION<br>HISTORY                                          |  |

 $\star$ 

# NEC

# Facsimile Message

Although NEC has taken all possible steps to ensure that the documentation supplied to our customers is complete, bug free and up-to-date, we readily accept that errors may occur. Despite all the care and precautions we've taken, you may encounter problems in the documentation. Please complete this form whenever you'd like to report errors or suggest improvements to us.

FAX

Address

Tel.

From:

Name

Company

Thank you for your kind support.

| North America<br>NEC Electronics Inc.<br>Corporate Communications Dept.<br>Fax: +1-800-729-9288<br>+1-408-588-6130 | Hong Kong, Philippines, Oceania<br>NEC Electronics Hong Kong Ltd.<br>Fax: +852-2886-9022/9044 | <b>Taiwan</b><br>NEC Electronics Taiwan Ltd.<br>Fax: +886-2-2719-5951                        |
|--------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|
| Europe<br>NEC Electronics (Europe) GmbH<br>Market Communication Dept.<br>Fax: +49-211-6503-274                     | <b>Korea</b><br>NEC Electronics Hong Kong Ltd.<br>Seoul Branch<br>Fax: +82-2-528-4411         | Asian Nations except Philippines<br>NEC Electronics Singapore Pte. Ltd.<br>Fax: +65-250-3583 |
| South America<br>NEC do Brasil S.A.<br>Fax: +55-11-6462-6829                                                       | <b>P.R. China</b><br>NEC Electronics Shanghai, Ltd.<br>Fax: +86-21-6841-1137                  | <b>Japan</b><br>NEC Semiconductor Technical Hotline<br>Fax: +81- 44-435-9608                 |

I would like to report the following error/make the following suggestion:

Document title: \_\_\_\_

Document number: \_\_\_\_

\_\_\_\_\_ Page number: \_\_\_\_\_

If possible, please fax the referenced page or drawing.

| <b>Document Rating</b> | Excellent | Good | Acceptable | Poor |
|------------------------|-----------|------|------------|------|
| Clarity                |           |      |            |      |
| Technical Accuracy     |           |      |            |      |
| Organization           |           |      |            |      |