# Old Company Name in Catalogs and Other Documents

On April 1<sup>st</sup>, 2010, NEC Electronics Corporation merged with Renesas Technology Corporation, and Renesas Electronics Corporation took over all the business of both companies. Therefore, although the old company name remains in this document, it is a valid Renesas Electronics document. We appreciate your understanding.

Renesas Electronics website: http://www.renesas.com

April 1<sup>st</sup>, 2010 Renesas Electronics Corporation

Issued by: Renesas Electronics Corporation (http://www.renesas.com)

Send any inquiries to http://www.renesas.com/inquiry.

#### Notice

- 1. All information included in this document is current as of the date this document is issued. Such information, however, is subject to change without any prior notice. Before purchasing or using any Renesas Electronics products listed herein, please confirm the latest product information with a Renesas Electronics sales office. Also, please pay regular and careful attention to additional and different information to be disclosed by Renesas Electronics such as that disclosed through our website.
- Renesas Electronics 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 Renesas Electronics products or technical information described in this document. No license, express, implied or otherwise, is granted hereby under any patents, copyrights or other intellectual property rights of Renesas Electronics or others.
- 3. You should not alter, modify, copy, or otherwise misappropriate any Renesas Electronics product, whether in whole or in part.
- 4. Descriptions of circuits, software and other related information in this document are provided only to illustrate the operation of semiconductor products and application examples. You are fully responsible for the incorporation of these circuits, software, and information in the design of your equipment. Renesas Electronics assumes no responsibility for any losses incurred by you or third parties arising from the use of these circuits, software, or information.
- 5. When exporting the products or technology described in this document, you should comply with the applicable export control laws and regulations and follow the procedures required by such laws and regulations. You should not use Renesas Electronics products or the technology described in this document for any purpose relating to military applications or use by the military, including but not limited to the development of weapons of mass destruction. Renesas Electronics products and technology may not be used for or incorporated into any products or systems whose manufacture, use, or sale is prohibited under any applicable domestic or foreign laws or regulations.
- 6. Renesas Electronics has used reasonable care in preparing the information included in this document, but Renesas Electronics does not warrant that such information is error free. Renesas Electronics assumes no liability whatsoever for any damages incurred by you resulting from errors in or omissions from the information included herein.
- 7. Renesas Electronics products are classified according to the following three quality grades: "Standard", "High Quality", and "Specific". The recommended applications for each Renesas Electronics product depends on the product's quality grade, as indicated below. You must check the quality grade of each Renesas Electronics product before using it in a particular application. You may not use any Renesas Electronics product for any application categorized as "Specific" without the prior written consent of Renesas Electronics. Further, you may not use any Renesas Electronics. Renesas Electronics shall not be in any way liable for any damages or losses incurred by you or third parties arising from the use of any Renesas Electronics product for an application categorized as "Specific" or for which the product is not intended where you have failed to obtain the prior written consent of Renesas Electronics. The quality grade of each Renesas Electronics product is "Standard" unless otherwise expressly specified in a Renesas Electronics data sheets or data books, etc.
  - "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.
  - "High Quality": Transportation equipment (automobiles, trains, ships, etc.); traffic control systems; anti-disaster systems; anticrime systems; safety equipment; and medical equipment not specifically designed for life support.
  - "Specific": Aircraft; aerospace equipment; submersible repeaters; nuclear reactor control systems; medical equipment or systems for life support (e.g. artificial life support devices or systems), surgical implantations, or healthcare intervention (e.g. excision, etc.), and any other applications or purposes that pose a direct threat to human life.
- 8. You should use the Renesas Electronics products described in this document within the range specified by Renesas Electronics, especially with respect to the maximum rating, operating supply voltage range, movement power voltage range, heat radiation characteristics, installation and other product characteristics. Renesas Electronics shall have no liability for malfunctions or damages arising out of the use of Renesas Electronics products beyond such specified ranges.
- 9. Although Renesas Electronics endeavors to improve the quality and reliability of its products, semiconductor products have specific characteristics such as the occurrence of failure at a certain rate and malfunctions under certain use conditions. Further, Renesas Electronics products are not subject to radiation resistance design. Please be sure to implement safety measures to guard them against the possibility of physical injury, and injury or damage caused by fire in the event of the failure of a Renesas Electronics product, such as safety design for hardware and software including but not limited to redundancy, fire control and malfunction prevention, appropriate treatment for aging degradation or any other appropriate measures. Because the evaluation of microcomputer software alone is very difficult, please evaluate the safety of the final products or system manufactured by you.
- 10. Please contact a Renesas Electronics sales office for details as to environmental matters such as the environmental compatibility of each Renesas Electronics product. Please use Renesas Electronics products in compliance with all applicable laws and regulations that regulate the inclusion or use of controlled substances, including without limitation, the EU RoHS Directive. Renesas Electronics assumes no liability for damages or losses occurring as a result of your noncompliance with applicable laws and regulations.
- 11. This document may not be reproduced or duplicated, in any form, in whole or in part, without prior written consent of Renesas Electronics.
- 12. Please contact a Renesas Electronics sales office if you have any questions regarding the information contained in this document or Renesas Electronics products, or if you have any other inquiries.
- (Note 1) "Renesas Electronics" as used in this document means Renesas Electronics Corporation and also includes its majorityowned subsidiaries.
- (Note 2) "Renesas Electronics product(s)" means any product developed or manufactured by or for Renesas Electronics.

# RENESAS

# M16C/80 Series Programming Guidelines <Assembly Language>

# Preface

This manual describes the basic knowledge of application program development for the M16C/80 series of Renesas CMOS 16-bit microcomputers. The programming language used in this manual is the assembly language.

If you are using the M16C/80 series for the first time, refer to Chapter 1, "Overview of M16C/80 Series". If you want to know the CPU architecture and instructions, refer to Chapter 2, "CPU Programming Model" or if you want to know the directive commands of the assembler, refer to Chapter 3, "Functions of Assembler". If you want to know practical techniques, refer to Chapter 4, "Programming Style".

The instruction set of the M16C/80 series is detailed in "M16C/80 Series Software Manual". Refer to this manual when the knowledge of the instruction set is required.

For information about the hardware of each type of microcomputer in the M16C/80 series, refer to the user's manual supplied with your microcomputer. For details about the development support tools, refer to the user's manual of each tool.

# Guide to Using This Manual

This manual is an assembly language programming guidelines for the M16C/80 series. This manual can be used in common for all types of microcomputers built the M16C/80 series CPU core. This manual is written assuming that the reader has a basic knowledge of electrical circuits, logic circuits, and microcomputers.

This manual consists of four chapters. The following provides a brief guide to the desired chapters and sections.

- To see the overview and features of the M16C/80 series
  - -> Chapter 1 Overview of M16C/80 Series

• To understand the address space, register structure, and addressing and other knowledge required for programming

-> Chapter 2 CPU Programming Model

• To know the functions of instructions, the method for writing instructions, and the usable addressing modes

- -> Chapter 2 CPU Programming Model, 2.6 Instruction Set
- To know how to use interrupts
  - -> Chapter 2 CPU Programming Model, 2.7 Outline of Interrupt
  - -> Chapter 4 Programming Style, 4.3 Setting when using Interrupts
- To check the functions of and the method for writing directive commands -> Chapter 3 Functions of Assembler, 3.2 Method for Writing Source Program
- To know the M16C/80 series' programming techniques -> Chapter 4 Programming Style, 4.5 A Little Tips...(Programing technique)
- To know the M16C/80 series' development procedures -> Appendix Command input form and command parameters in AS308 system

# **Table of contents**

| Chapter 1 Overview of M16C/80 Series                  | 5  |
|-------------------------------------------------------|----|
| 1.1 Features of M16C/80 Series                        | 6  |
| 1.2 Outline of M16C/80 Group                          | 7  |
| Chapter 2 CPU Programming Model                       |    |
| 2.1 Address Space                                     | 11 |
| 2.1.1 Operation Modes and Memory Mapping              |    |
| 2.1.2 SFR Alea                                        |    |
| 2.2 Register Set                                      | 19 |
| 2.3 Data Types                                        | 25 |
| 2.4 Data Arrangement                                  | 27 |
| 2.5 Addressing Modes                                  | 28 |
| 2.5.1 General Instruction Addressing                  |    |
| 2.5.2 Indirect instruction Addressing                 |    |
| 2.5.3 Special Instruction Addressing                  |    |
| 2.5.4 Bit Instruction Addressing                      |    |
| 2.6 Instruction Set                                   | 48 |
| 2.6.1 Instruction Description                         |    |
| 2.6.2 Instruction List                                |    |
| 2.6.3 Transfer Instructions                           | 71 |
| 2.6.4 Arithmetic Instructions                         | 75 |
| 2.6.5 Branch Instructions                             |    |
| 2.6.6 Bit Instructions                                |    |
| 2.6.7 Sign-extension instruction                      |    |
| 2.6.8 Index instruction                               |    |
| 2.6.9 High-level language and OS support instructions |    |

| 2.7 Outline of Interrupt 09                                                                                                                                                                                                                                                                                                                    |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2.7 Outline of Interrupt                                                                                                                                                                                                                                                                                                                       |
| 2.7.1 Interrupt Sources and Vector addresses                                                                                                                                                                                                                                                                                                   |
| 2.7.2 Variable vector table                                                                                                                                                                                                                                                                                                                    |
| 2.7.3 Interrupt generation conditions                                                                                                                                                                                                                                                                                                          |
| and interrupt control register bit configuration                                                                                                                                                                                                                                                                                               |
| 2.7.4 Interrupt acceptance timing and sequence                                                                                                                                                                                                                                                                                                 |
| 2.7.5 Interrupt priority106                                                                                                                                                                                                                                                                                                                    |
| Chapter 3 Functions of Assembler 108                                                                                                                                                                                                                                                                                                           |
| 3.1 Outline of AS308 System109                                                                                                                                                                                                                                                                                                                 |
| 3.2 Method for Writing Source Program112                                                                                                                                                                                                                                                                                                       |
| 3.2.1 Basic Rules                                                                                                                                                                                                                                                                                                                              |
| 3.2.2 Address Control 120                                                                                                                                                                                                                                                                                                                      |
| 3.2.3 Directive Commands 127                                                                                                                                                                                                                                                                                                                   |
| 3.2.4 Macro Functions134                                                                                                                                                                                                                                                                                                                       |
|                                                                                                                                                                                                                                                                                                                                                |
| 3.2.5 Differences with M16C/60141                                                                                                                                                                                                                                                                                                              |
| 3.2.5 Differences with M16C/60141<br>Chapter 4 Programming Style                                                                                                                                                                                                                                                                               |
|                                                                                                                                                                                                                                                                                                                                                |
| Chapter 4 Programming Style 146                                                                                                                                                                                                                                                                                                                |
| Chapter 4 Programming Style 146<br>4.1 Hardware Definition                                                                                                                                                                                                                                                                                     |
| Chapter 4 Programming Style                                                                                                                                                                                                                                                                                                                    |
| Chapter 4 Programming Style                                                                                                                                                                                                                                                                                                                    |
| Chapter 4 Programming Style       146         4.1 Hardware Definition       147         4.1.1 Defining SFR Area       147         4.1.2 Allocating RAM Data Area       150         4.1.3 Allocating ROM Data Area       151                                                                                                                    |
| Chapter 4 Programming Style1464.1 Hardware Definition1474.1.1 Defining SFR Area1474.1.2 Allocating RAM Data Area1504.1.3 Allocating ROM Data Area1514.1.4 Defining a Section152                                                                                                                                                                |
| Chapter 4 Programming Style                                                                                                                                                                                                                                                                                                                    |
| Chapter 4 Programming Style1464.1 Hardware Definition1474.1.1 Defining SFR Area1474.1.2 Allocating RAM Data Area1504.1.3 Allocating ROM Data Area1514.1.4 Defining a Section1524.1.5 Sample Program List 1 (Initial Setting 1)1544.2 Initial Setting the CPU157                                                                                |
| Chapter 4 Programming Style                                                                                                                                                                                                                                                                                                                    |
| Chapter 4 Programming Style1464.1 Hardware Definition1474.1.1 Defining SFR Area1474.1.2 Allocating RAM Data Area1504.1.3 Allocating ROM Data Area1514.1.4 Defining a Section1524.1.5 Sample Program List 1 (Initial Setting 1)1544.2 Initial Setting the CPU1574.2.1 Setting CPU Internal Registers1574.2.2 Setting Stack Pointer158           |
| Chapter 4 Programming Style1464.1 Hardware Definition1474.1.1 Defining SFR Area1474.1.2 Allocating RAM Data Area1504.1.3 Allocating ROM Data Area1514.1.4 Defining a Section1524.1.5 Sample Program List 1 (Initial Setting 1)1544.2 Initial Setting the CPU1574.2.1 Setting CPU Internal Registers1574.2.3 Setting Base Registers (SB, FB)158 |

| RENESAS |
|---------|
|---------|

| 4.3 Setting when using Interrupts                                                                                        | 167 |
|--------------------------------------------------------------------------------------------------------------------------|-----|
| 4.3.1 Setting Interrupt Table Register(INTB)                                                                             |     |
| 4.3.2 Setting Variable/Fixed Vectors                                                                                     |     |
| 4.3.3 Setting Interrupt Control Register                                                                                 |     |
| 4.3.4 Enabling Interrupt Enable Flag( I flag)                                                                            |     |
| 4.3.5 Saving and Restoring Registers in Interrupt Handler Routine                                                        | 170 |
| 4.3.6 Sample Program List 3 (Using interrupts)                                                                           |     |
| 4.3.7 ISP and USP                                                                                                        |     |
| 4.3.8 Multiple Interrupts                                                                                                |     |
| 4.3.9 High-speed interrupts                                                                                              |     |
| 4.4 Dividing Source File                                                                                                 | 185 |
| 4.4.1 Concept of Sections                                                                                                |     |
| 4.4.2 Example of program description in divided files                                                                    |     |
| 4.4.3 Using library files                                                                                                |     |
| 4.5 A Little Tips(Programing technique)                                                                                  | 195 |
| 4.5.1 Setup Values of SB and FB Registers                                                                                |     |
| 4.5.2 Specifying ROM/RAM data alignments                                                                                 |     |
| 4.5.3 Setting stack pointer                                                                                              |     |
| 4.5.4 Using special pages                                                                                                |     |
| 4.5.5 Example for using software interrupt (INTO instruction)                                                            |     |
| 4.5.6 Software runway prevention                                                                                         |     |
| 4.5.7 Method for using the "-LOC" option                                                                                 |     |
| 4.6 Standard processing program                                                                                          | 213 |
| Appendix                                                                                                                 | 215 |
| Appendix A. Generating Object Files                                                                                      | 216 |
| Appendix A Generating Object Files                                                                                       |     |
|                                                                                                                          |     |
| Appendix A-1 Assembling (as308)                                                                                          |     |
| Appendix A-1 Assembling (as308)<br>Appendix A-2 Linking(In308)<br>Appendix A-3 Generating Machine Language File (Imc308) |     |



# **Chapter 1**

# **Overview of M16C/80 Series**

- 1.1 Features of M16C/80 Series
- 1.2 Outline of M16C/80 Group

# 1.1 Features of M16C/80 Series

The M16C/80 series is a line of single-chip microcomputers that have been developed for use in built-in equipment. This section describes the features of the M16C/80 series.

# Features of the M16C/80 series

The M16C/80 series has its frequently used instructions placed in a 1-byte op-code. For this reason, it allows you to write a highly memory efficient program.

Furthermore, although the M16C/80 series is a 16-bit microcomputer, it can perform 1, 4, and 8-bit processing efficiently. Especially, 32-bit processing is handled more efficiently than in the M16C/60 series. The M16C/80 series has many instructions that can be executed in one clock period. For this reason, it is possible to write a high-speed processing program.

The M16C/80 series provides 1 M bytes of linear addressing space. Therefore, the M16C/80 series is also suitable for applications that require a large program size.

The features of the M16C/80 series can be summarized as follows:

- (1) The M16C/80 series allows you to create a memory-efficient program without requiring a large memory capacity.
- (2) The M16C/80 series allows you to create a high- speed processing program.
- (3) The M16C/80 series provides 1 M bytes of addressing space, making it suitable for even largecapacity applications.

# 1.2 Outline of M16C/80 Group

This section introduces the M16C/80 group by way of explaining the internal configuration of the M16C/80 series. The M16C/80 group is a product that comprises the basis of the M16C/80 series. For details about this product, refer to the data sheets and user's manuals.

## **Internal Block Diagram**



# **Outline Specifications of the M16C/80 Group**

Table 1.2.1 lists the outline specifications of the M16C/80 group.

#### Table 1.2.1 Outline Specifications of M16C/80 Group

| Item                                |                              | Performance                                           |
|-------------------------------------|------------------------------|-------------------------------------------------------|
| Number of basic instructions        |                              | 106 instructions                                      |
| Shortest instruction execution time |                              | 50ns(f(XIN)=20MHz)                                    |
| Memory                              | ROM                          | 128K bytes                                            |
| capacity                            | RAM                          | 10K bytes                                             |
| I/O port                            | P0 to P10 (except P85)       | 8 bits x 10, 7 bits x 1 (100-pin version)             |
|                                     | P0 to P15 (except P85)       | 8 bits x 10, 7 bits x 1, 5 bits x 1 (144-pin version) |
| Input port                          | P85                          | 1 bit x 1                                             |
| Multifunction                       | TA0, TA1, TA2, TA3,TA4       | 16 bits x 5                                           |
| timer                               | TB0, TB1, TB2, TB3, TB4, TB5 | 16 bits x 6                                           |
| Serial I/O                          | UART0, UART1, UART2,         | (UART or clock synchronous) x 5                       |
|                                     | UART3, UART4                 |                                                       |
| A-D converter                       |                              | 10 bits x (8 + 2) channels                            |
| D-A converter                       |                              | 8 bits x 2                                            |
| DMAC                                |                              | 4 channels                                            |
| DRAM contro                         | ller                         | CAS before RAS refresh, self-refresh, EDO, FP         |
| CRC calculati                       | on circuit                   | CRC-CCITT                                             |
| X-Y converter                       |                              | 16 bits X 16 bits                                     |
| Watchdog timer                      |                              | 15 bits x 1 (with prescaler)                          |
| Interrupt                           |                              | 29 internal and 8 external sources, 4 software        |
|                                     |                              | sources, 7 levels                                     |
| Clock generating circuit            |                              | 2 built-in clock generation circuits                  |
|                                     |                              | (built-in feedback resistor, and external ceramic or  |
|                                     |                              | quartz oscillator)                                    |
| Memory expansion                    |                              | Available (up to 16 Mbytes)                           |

Note: The above specifications are for the M30800MC. For details the memory size, refer to the data sheet and user's manual.



### **Register Structure**

Table 1.2.2 shows the register structure of the M16C/80 series. Eight registers--R0, R1, R2, R3, A0, A1, SB, and FB--are available in two sets each. These sets are switched over by a register bank select flag.

#### Table 1.2.2 Register Structure of M16C/80 Series

| Item                           |                                                                                                                | Content                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------------------------------|----------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| egister structure              |                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Data registers                 | R0 b15 b0<br>R1 R2 R3 R3                                                                                       | b31         b0         b7         b0         b7         b0           R2R0         R2         R0         R0         R0L         R0L |
| Address registers              | A0 A1                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Base registers                 | b23         b0           SB         FB         FB                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Control registers              | b23         b0           PC                                                                                    | <ul> <li>(Details of FLG)</li> <li>IPL</li> <li>IPL</li> <li>IUIOBSZDC</li> </ul> IPL : Processor interrupt priority level (Levels 0 to 7; larger the number, higher the priority) U : Stack pointer select flag (ISP when U = 0, USP when U = 0)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| High-speed interrupt registers | b15         b0           SVF            b23         b0           SVP                                           | <ul> <li>Interrupt enable flag (Enabled when I = 1)</li> <li>Overflow flag (0 = 1 when overflow occurs)</li> <li>B : Register bank select flag (Register bank 0 when B = 0, register bank 1 when B = 1)</li> <li>S : Sign flag (S = 1 when operation resulted in negative, S = 0 when positive)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| DMAC related<br>registers      | DMD0<br>DMD1<br>b15<br>b0<br>DCT0<br>DCT1<br>DRC0<br>DRC1<br>b23<br>b0<br>DMA0<br>DMA0<br>DSA1<br>DRA0<br>DRA1 | <ul> <li>Zero flag (Z = 1 when operation resulted in zero)</li> <li>D : Debug flag (Program is single-stepped when D = 1)</li> <li>C : Carry flag (carry or borrow)</li> <li>: Reserved area</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |



# **Chapter 2**

# **CPU Programming Model**

- 2.1 Address Space
- 2.2 Register Sets
- 2.3 Data Types
- 2.4 Data Arrangement
- 2.5 Addressing Modes
- 2.6 Instruction Set
- 2.7 Outline of Interrupt



# 2.1 Address Space

The M16C/80 series has 16 M bytes of address space ranging from address 000000H to address FFFFFH. This section explains the address space and memory mapping, the SFR area, and the fixed vector area of the M16C/80 group.

## **Address Space**

Figure 2.1.1 shows the address space of the M16C/80 group.

Addresses 000000H to 0003FFH are the Special Function Register (SFR) area. The SFR area in each type of M16C/80 group microcomputer begins with address 0003FFH and expands toward smaller addresses.

Addresses following 000400H constitute the memory area. The memory area in each type of M16C/80 group microcomputer consists of a RAM area which begins with address 00400H and expands toward larger addresses and a ROM area which begins with address FFFFFH and expands toward smaller addresses. However, addresses FFFE00H to FFFFFFH are the fixed vector area.



# 2.1.1 Operation Modes and Memory Mapping

The M16C/80 group chooses one operation mode from three modes available: single-chip, memory expansion, and microprocessor modes. The M16C/80 group address space and the usable areas and memory mapping varies with each operation mode.



### **Operation Modes and Memory Mapping**

- Single-chip mode In this mode, only the internal areas (SFR, internal RAM, and internal ROM) can be accessed.
- Memory expansion mode
   Memory expansion mode

In this mode, the internal areas (SFR, internal RAM, and internal ROM) and an external memory area can be accessed.

• Microprocessor mode In this mode, the SFR and internal RAM areas and an external memory area can be accessed. (The internal ROM area cannot be accessed.)

Figure 2.1.2 shows the M16C/80 group memory mapping in each operation mode.



(ROM: 128 Kbytes; RAM: 10 Kbytes Example)





## 2.1.2 SFR Area

A range of control registers are allocated in this area, including the processor mode register that determines the operation mode and the peripheral unit control registers for I/O ports, A-D converter, UART, and timers. For the bit configurations of these control registers, refer to the M16C/80 group data sheets and user's manuals.

The unused locations in the SFR area are reserved for the system and cannot be used by the user.

### SFR Area: Control Register Allocation (100-pin version)

Figures 2.1.3,2.1.4,2.1.5 and 2.1.6 show control register allocations in the SFR area.

| 00016          |                                                                                | 006016           |                                                                                                 |
|----------------|--------------------------------------------------------------------------------|------------------|-------------------------------------------------------------------------------------------------|
| 00116          |                                                                                | 006116           |                                                                                                 |
| 00216          |                                                                                | 006216           |                                                                                                 |
| 00316          |                                                                                | 006316           |                                                                                                 |
| 00416          | Processor mode register 0 (PM0)                                                | 006416           |                                                                                                 |
| 00516          | Processor mode register 1(PM1)                                                 | 006516<br>006616 |                                                                                                 |
| 00616<br>00716 | System clock control register 0 (CM0)<br>System clock control register 1 (CM1) | 006616           |                                                                                                 |
| 0716           | Wait control register (WCR)                                                    | 006716           | DMA0 interment control or sister (DM010)                                                        |
| 0916           | Address match interrupt enable register (AIER)                                 | 006916           | DMA0 interrupt control register (DM0IC)                                                         |
| 0A16           | Protect register (PRCR)                                                        | 006A16           | Timer B5 interrupt control register (TB5IC)                                                     |
| 0B16           | External data bus widthcontrol register (DS)                                   | 006B16           | DMA2 interrupt control register (DM1IC)<br>UART2 receive/ACK interrupt control register (S2RIC) |
| 0C16           | Main clock division register (MCD)                                             | 006C16           | Timer A0 interrupt control register (TA0IC)                                                     |
| 0D16           |                                                                                | 006D16           | UART3 receive/ACK interrupt control register (S3RIC)                                            |
| DE16           | Watchdog timer start register (WDTS)                                           | 006E16           | Timer A2 interrupt control register (TA2IC)                                                     |
| 0F16           | Watchdog timer control register (WDC)                                          | 006F16           | UART4 receive/ACK interrupt control register (S4RIC)                                            |
| 1016           | <b>o o</b> ( <i>'</i>                                                          | 007016           | Timer A4 interrupt control register (TA4IC)                                                     |
| 1116           | Address match interrupt register 0 (RMAD0)                                     | 007116           | Bus collision detection(UART3) interrupt control register (BCN3IC)                              |
| 1216           | 1 0 ( )                                                                        | 007216           | UART0 receive interrupt control register (SORIC)                                                |
| 1316           |                                                                                | 007316           | A-D conversion interrupt control register (ADIC)                                                |
| 1416           |                                                                                | 007416           | UART1 receive interrupt control register (S1RIC)                                                |
| 1516           | Address match interrupt register 1 (RMAD1)                                     | 007516           |                                                                                                 |
| 616            |                                                                                | 007616           | Timer B1 interrupt control register (TB1IC)                                                     |
| 716            |                                                                                | 007716           |                                                                                                 |
| 1816           |                                                                                | 007816           | Timer B3 interrupt control register (TB3IC)                                                     |
| 1916           | Address match interrupt register 2 (RMAD2)                                     | 007916           |                                                                                                 |
| 1A16           |                                                                                | 007A16           | INT5 interrupt control register (INT5IC)                                                        |
| 1B16           |                                                                                | 007B16           |                                                                                                 |
| 1C16           | Address match interrupt register 3 (RMAD3)                                     | 007C16           | INT3 interrupt control register (INT3IC)                                                        |
| 1D16           | Address match metrupt register 5 (RMAD5)                                       | 007D16           |                                                                                                 |
| IE16<br>IF16   |                                                                                | 007E16<br>007F16 | INT1 interrupt control register (INT1IC)                                                        |
| 2016           |                                                                                | 007F16           |                                                                                                 |
| 2018           | Emulator interrupt vector table register (EIAD) *                              | 008016           |                                                                                                 |
| 2216           |                                                                                | 008216           |                                                                                                 |
| 2316           | Emulator interrupt detect register (EITD) *                                    | 008316           |                                                                                                 |
| 2416           | Emulator protect register (EPRR) *                                             | 008416           |                                                                                                 |
| 2516           |                                                                                | 008516           |                                                                                                 |
| 2616           |                                                                                | 008616           |                                                                                                 |
| 2716           |                                                                                | 008716           |                                                                                                 |
| 2816           |                                                                                | 008816           | DMA1 interrupt control register (DM1IC)                                                         |
| 2916           |                                                                                | 008916           | UART2 transmit/NACK interrupt control register (S2TIC)                                          |
| 2A16           |                                                                                | 008A16           | DMA3 interrupt control register (DM3IC)                                                         |
| 2B16           |                                                                                | 008B16           | UART3 transmit/NACK interrupt control register (S3TIC)                                          |
| 2C16           |                                                                                | 008C16           | Timer A1 interrupt control register (TA1IC)                                                     |
| )2D16          |                                                                                | 008D16           | UART4 transmit/NACK interrupt control register (S4TIC)                                          |
| )2E16          |                                                                                | 008E16           | Timer A3 interrupt control register (TA3IC)                                                     |
| )2F16          |                                                                                | 008F16           | Bus collision detection(UART2) interrupt control register (BCN2IC)                              |
| 3016           | ROM areaset register (ROA) *                                                   | 009016           | UART0 transmit interrupt control register (S0TIC)                                               |
| 3116           | Debug monitor area set register (DBA) *                                        | 009116           | Bus collision detection(UART4) interrupt control register (BCN4IC)                              |
| 3216           | Expansion area set register 0 (EXA0) *                                         | 009216           | UART1 transmit interrupt control register (S1TIC)                                               |
| 3316           | Expansion area set register 1 (EXA1) *                                         | 009316           | Key input interrupt control register (KUPIC)                                                    |
| 3416           | Expansion area set register 2 (EXA2) *                                         | 009416           | Timer B0 interrupt control register (TB0IC)                                                     |
| )3516<br>)3616 | Expansion area set register 3 (EXA3) *                                         | 009516           |                                                                                                 |
| 3616<br>3716   |                                                                                | 009616<br>009716 | Timer B2 interrupt control register (TB2IC)                                                     |
| 3816           |                                                                                | 009716           | Times D4 interrupt control rs sister (TD 40)                                                    |
| 3916           |                                                                                | 009816           | Timer B4 interrupt control register (TB4IC)                                                     |
| 3A16           |                                                                                | 009916<br>009A16 | INT4 interrupt control register (INT410)                                                        |
| 3B16           |                                                                                | 009B16           | INT4 interrupt control register (INT4IC)                                                        |
| 3C16           |                                                                                | 009D16           | INT2 interrupt control register (INT2IC)                                                        |
| 3D16           |                                                                                | 009D16           | INT2 interrupt control register (INT2IC)                                                        |
| 3E16           |                                                                                | 009E16           | INT0 interrupt control register (INT0IC)                                                        |
| 3F16           |                                                                                | 009F16           | Exit priority register (RLVL)                                                                   |
| 4016           | DRAM control register (DRAMCONT)                                               | 00A016           |                                                                                                 |
| 4116           | DRAM reflesh interval set register (REFCNT)                                    | 00A116           |                                                                                                 |
|                |                                                                                | 00A216           |                                                                                                 |
| )4216          |                                                                                |                  |                                                                                                 |
| )4216<br>)4316 |                                                                                | 00A316           |                                                                                                 |

Figure 2.1.3 Control register allocation 1

# RENESAS

| 02C016                                                                                                                                                                                                                                                                                                         | X0 register (X0R) Y0 register (Y0R)                                                                                                                                                                                                                                                                                                                                                        |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 02C116<br>02C216                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                            |
| 02C316                                                                                                                                                                                                                                                                                                         | X1 register (X1R) Y1 register (Y1R)                                                                                                                                                                                                                                                                                                                                                        |
| 02C416                                                                                                                                                                                                                                                                                                         | X2 register (X2R) Y2 register (Y2R)                                                                                                                                                                                                                                                                                                                                                        |
| 02C516<br>02C616                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                            |
| 02C018<br>02C716                                                                                                                                                                                                                                                                                               | X3 register (X3R) Y3 register (Y3R)                                                                                                                                                                                                                                                                                                                                                        |
| 02C816                                                                                                                                                                                                                                                                                                         | X4 register (X4R) Y4 register (Y4R)                                                                                                                                                                                                                                                                                                                                                        |
| 02C916<br>02CA16                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                            |
| 02CB16                                                                                                                                                                                                                                                                                                         | X5 register (X5R) Y5 register (Y5R)                                                                                                                                                                                                                                                                                                                                                        |
| 02CC16<br>02CD16                                                                                                                                                                                                                                                                                               | X6 register (X6R) Y6 register (Y6R)                                                                                                                                                                                                                                                                                                                                                        |
| 02CE16<br>02CF16                                                                                                                                                                                                                                                                                               | X7 register (X7R) Y7 register (Y7R)                                                                                                                                                                                                                                                                                                                                                        |
| 02D016<br>02D116                                                                                                                                                                                                                                                                                               | X8 register (X8R) Y8 register (Y8R)                                                                                                                                                                                                                                                                                                                                                        |
| 02D216<br>02D316                                                                                                                                                                                                                                                                                               | X9 register (X9R) Y9 register (Y9R)                                                                                                                                                                                                                                                                                                                                                        |
| 02D316                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                            |
| 02D516                                                                                                                                                                                                                                                                                                         | X10 register (X10R) Y10 register (Y10R)                                                                                                                                                                                                                                                                                                                                                    |
| 02D616<br>02D716                                                                                                                                                                                                                                                                                               | X11 register (X11R) Y11 register (Y11R)                                                                                                                                                                                                                                                                                                                                                    |
| 02D816<br>02D916                                                                                                                                                                                                                                                                                               | X12 register (X12R) Y12 register (Y12R)                                                                                                                                                                                                                                                                                                                                                    |
| 02DA16                                                                                                                                                                                                                                                                                                         | X13 register (X13R) Y13 register (Y13R)                                                                                                                                                                                                                                                                                                                                                    |
| 02DB16<br>02DC16                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                            |
| 02DD16                                                                                                                                                                                                                                                                                                         | X14 register (X14R) Y14 register (Y14R)                                                                                                                                                                                                                                                                                                                                                    |
| 02DE16<br>02DF16                                                                                                                                                                                                                                                                                               | X15 register (X15R) Y15 register (Y15R)                                                                                                                                                                                                                                                                                                                                                    |
| 0201.10                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                            |
| 02E016                                                                                                                                                                                                                                                                                                         | XY control register (XYC)                                                                                                                                                                                                                                                                                                                                                                  |
| 02E016<br>02E116                                                                                                                                                                                                                                                                                               | XY control register (XYC)                                                                                                                                                                                                                                                                                                                                                                  |
| 02E016<br>02E116<br>02E216                                                                                                                                                                                                                                                                                     | XY control register (XYC)                                                                                                                                                                                                                                                                                                                                                                  |
| 02E016<br>02E116                                                                                                                                                                                                                                                                                               | XY control register (XYC)                                                                                                                                                                                                                                                                                                                                                                  |
| 02E016<br>02E116<br>02E216<br>02E316                                                                                                                                                                                                                                                                           | XY control register (XYC)                                                                                                                                                                                                                                                                                                                                                                  |
| 02E016<br>02E116<br>02E216<br>02E316<br>02E416<br>02E516<br>02E616                                                                                                                                                                                                                                             | XY control register (XYC)                                                                                                                                                                                                                                                                                                                                                                  |
| 02E016<br>02E116<br>02E316<br>02E316<br>02E416<br>02E516<br>02E616<br>02E616                                                                                                                                                                                                                                   | XY control register (XYC)                                                                                                                                                                                                                                                                                                                                                                  |
| 02E016<br>02E116<br>02E216<br>02E316<br>02E416<br>02E516<br>02E616<br>02E716<br>02E816                                                                                                                                                                                                                         | XY control register (XYC)                                                                                                                                                                                                                                                                                                                                                                  |
| 02E016<br>02E116<br>02E216<br>02E316<br>02E416<br>02E516<br>02E616<br>02E616                                                                                                                                                                                                                                   | XY control register (XYC)                                                                                                                                                                                                                                                                                                                                                                  |
| 02E016<br>02E116<br>02E216<br>02E316<br>02E416<br>02E516<br>02E616<br>02E616<br>02E716<br>02E816<br>02E816<br>02E916                                                                                                                                                                                           | XY control register (XYC)                                                                                                                                                                                                                                                                                                                                                                  |
| 02E016<br>02E116<br>02E216<br>02E316<br>02E416<br>02E516<br>02E616<br>02E716<br>02E916<br>02E916<br>02EA16<br>02EB16<br>02EC16                                                                                                                                                                                 | XY control register (XYC)                                                                                                                                                                                                                                                                                                                                                                  |
| 02E016<br>02E116<br>02E216<br>02E316<br>02E516<br>02E516<br>02E716<br>02E816<br>02E916<br>02EA16<br>02EB16<br>02EC16                                                                                                                                                                                           | XY control register (XYC)                                                                                                                                                                                                                                                                                                                                                                  |
| 02E016<br>02E116<br>02E216<br>02E316<br>02E516<br>02E516<br>02E716<br>02E816<br>02E916<br>02E816<br>02E016<br>02E016<br>02E16                                                                                                                                                                                  | XY control register (XYC)                                                                                                                                                                                                                                                                                                                                                                  |
| 02E016<br>02E116<br>02E216<br>02E316<br>02E416<br>02E516<br>02E716<br>02E916<br>02E916<br>02E916<br>02E016<br>02E016<br>02E16<br>02E516                                                                                                                                                                        | XY control register (XYC)                                                                                                                                                                                                                                                                                                                                                                  |
| 02E016<br>02E116<br>02E216<br>02E316<br>02E516<br>02E516<br>02E716<br>02E816<br>02E916<br>02E816<br>02E016<br>02E016<br>02E16                                                                                                                                                                                  | XY control register (XYC)                                                                                                                                                                                                                                                                                                                                                                  |
| 02E016<br>02E116<br>02E216<br>02E316<br>02E416<br>02E516<br>02E716<br>02E916<br>02E916<br>02E816<br>02E16<br>02E16<br>02E16<br>02E16<br>02E716                                                                                                                                                                 | XY control register (XYC)                                                                                                                                                                                                                                                                                                                                                                  |
| 02E016<br>02E116<br>02E216<br>02E316<br>02E516<br>02E516<br>02E716<br>02E916<br>02E916<br>02E16<br>02E16<br>02E16<br>02E16<br>02E16<br>02E716                                                                                                                                                                  | XY control register (XYC)                                                                                                                                                                                                                                                                                                                                                                  |
| 02E016<br>02E116<br>02E216<br>02E316<br>02E416<br>02E516<br>02E716<br>02E916<br>02E916<br>02E816<br>02E16<br>02E16<br>02E16<br>02E16<br>02E716<br>02F16<br>02F116                                                                                                                                              | XY control register (XYC)                                                                                                                                                                                                                                                                                                                                                                  |
| 02E016<br>02E16<br>02E316<br>02E316<br>02E516<br>02E616<br>02E716<br>02E916<br>02E816<br>02E616<br>02E16<br>02E16<br>02E16<br>02E16<br>02E716<br>02F16<br>02F316                                                                                                                                               | XY control register (XYC)                                                                                                                                                                                                                                                                                                                                                                  |
| 02E016<br>02E116<br>02E216<br>02E316<br>02E516<br>02E516<br>02E716<br>02E916<br>02E416<br>02E616<br>02E716<br>02E716<br>02F16<br>02F116<br>02F116<br>02F316<br>02F316                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                            |
| 02E016<br>02E16<br>02E316<br>02E316<br>02E516<br>02E516<br>02E716<br>02E916<br>02E416<br>02E616<br>02E616<br>02E716<br>02E716<br>02F16<br>02F16<br>02F316<br>02F316<br>02F316                                                                                                                                  | UART4 special mode register 3 (U4SMR3)                                                                                                                                                                                                                                                                                                                                                     |
| 02E016<br>02E16<br>02E316<br>02E416<br>02E516<br>02E616<br>02E716<br>02E916<br>02E416<br>02E016<br>02E16<br>02E16<br>02F16<br>02F16<br>02F316<br>02F316<br>02F316<br>02F316                                                                                                                                    | UART4 special mode register 3 (U4SMR3)<br>UART4 special mode register 2 (U4SMR2)                                                                                                                                                                                                                                                                                                           |
| 02E016<br>02E116<br>02E216<br>02E316<br>02E516<br>02E616<br>02E716<br>02E916<br>02E916<br>02E16<br>02E16<br>02E16<br>02E16<br>02F16<br>02F16<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316                                                                                                                 | UART4 special mode register 3 (U4SMR3)<br>UART4 special mode register 2 (U4SMR2)<br>UART4 special mode register (U4SMR)                                                                                                                                                                                                                                                                    |
| 02E016<br>02E16<br>02E316<br>02E416<br>02E516<br>02E616<br>02E716<br>02E916<br>02E916<br>02E16<br>02E16<br>02E716<br>02F16<br>02F16<br>02F316<br>02F416<br>02F416<br>02F416<br>02F416<br>02F416<br>02F416<br>02F416                                                                                            | UART4 special mode register 3 (U4SMR3)<br>UART4 special mode register 2 (U4SMR2)<br>UART4 special mode register 2 (U4SMR2)<br>UART4 special mode register (U4SMR)<br>UART4 transmit/receive mode register (U4MR)<br>UART4 bit rate generator (U4BRG)                                                                                                                                       |
| 02E016<br>02E16<br>02E316<br>02E316<br>02E516<br>02E616<br>02E716<br>02E916<br>02E916<br>02E16<br>02E16<br>02E716<br>02F16<br>02F16<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316                                          | UART4 special mode register 3 (U4SMR3)<br>UART4 special mode register 2 (U4SMR3)<br>UART4 special mode register 2 (U4SMR2)<br>UART4 special mode register (U4SMR)<br>UART4 transmit/receive mode register (U4MR)<br>UART4 transmit/receive mode register (U4MR)<br>UART4 transmit buffer register (U4TB)                                                                                   |
| 02E016<br>02E16<br>02E316<br>02E316<br>02E516<br>02E716<br>02E716<br>02E916<br>02E916<br>02E16<br>02E16<br>02E16<br>02E716<br>02F16<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316                                          | UART4 special mode register 3 (U4SMR3)<br>UART4 special mode register 2 (U4SMR3)<br>UART4 special mode register 2 (U4SMR2)<br>UART4 special mode register (U4SMR)<br>UART4 transmit/receive mode register (U4MR)<br>UART4 bit rate generator (U4BRG)<br>UART4 transmit buffer register (U4TB)<br>UART4 transmit buffer register (U4TB)<br>UART4 transmit/receive control register 0 (U4C0) |
| 02E016<br>02E16<br>02E316<br>02E316<br>02E516<br>02E716<br>02E916<br>02E916<br>02E916<br>02E916<br>02E16<br>02E16<br>02E716<br>02F16<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316 | UART4 special mode register 3 (U4SMR3)<br>UART4 special mode register 2 (U4SMR3)<br>UART4 special mode register 2 (U4SMR2)<br>UART4 special mode register (U4SMR)<br>UART4 transmit/receive mode register (U4MR)<br>UART4 transmit/receive mode register (U4MR)<br>UART4 transmit buffer register (U4TB)                                                                                   |
| 02E016<br>02E16<br>02E316<br>02E316<br>02E516<br>02E716<br>02E716<br>02E916<br>02E916<br>02E16<br>02E16<br>02E16<br>02E716<br>02F16<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316<br>02F316                                          | UART4 special mode register 3 (U4SMR3)<br>UART4 special mode register 2 (U4SMR3)<br>UART4 special mode register 2 (U4SMR2)<br>UART4 special mode register (U4SMR)<br>UART4 transmit/receive mode register (U4MR)<br>UART4 bit rate generator (U4BRG)<br>UART4 transmit buffer register (U4TB)<br>UART4 transmit buffer register (U4TB)<br>UART4 transmit/receive control register 0 (U4C0) |

| 030016           | Timer B3, 4, 5 count start flag (TBSR)                                             |
|------------------|------------------------------------------------------------------------------------|
| 030116           |                                                                                    |
| 030216           | Timer A1 1 register (TA11)                                                         |
| 030316           | Timer A1-1 register (TA11)                                                         |
| 030416           | Timer A2-1 register (TA21)                                                         |
| 030516           |                                                                                    |
| 030616           | Timer A4-1 register (TA41)                                                         |
| 030716           |                                                                                    |
| 030816           | Three-phase PWM control register 0(INVC0)                                          |
| 030916           | Three-phase PWM control register 1(INVC1)                                          |
| 030A16           | Thrree-phase output buffer register 0(IDB0)                                        |
| 030B16           | Thrree-phase output buffer register 1(IDB1)                                        |
| 030C16<br>030D16 | Dead time timer(DTT)<br>Timer B2 interrupt occurrence frequency set counter(ICTB2) |
| 030E16           |                                                                                    |
| 030F16           |                                                                                    |
| 031016           |                                                                                    |
| 031116           | Timer B3 register (TB3)                                                            |
| 031216           |                                                                                    |
| 031316           | Timer B4 register (TB4)                                                            |
| 031416           |                                                                                    |
| 031516           | Timer B5 register (TB5)                                                            |
| 031616           |                                                                                    |
| 031716           |                                                                                    |
| 031816           |                                                                                    |
| 031916           |                                                                                    |
| 031A16           |                                                                                    |
| 031B16           | Timer B3 mode register (TB3MR)                                                     |
| 031C16           | Timer B4 mode register (TB4MR)                                                     |
| 031D16           | Timer B5 mode register (TB5MR)                                                     |
| 031E16           |                                                                                    |
| 031F16           | Interrupt cause select register (IFSR)                                             |
| 032016           |                                                                                    |
| 032116           |                                                                                    |
| 032216           |                                                                                    |
| 032316           |                                                                                    |
| 032416           |                                                                                    |
| 032516           | UART3 special mode register 3 (U3SMR3)                                             |
| 032616           | UART3 special mode register 2 (U3SMR2)                                             |
| 032716<br>032816 | UART3 special mode register (U3SMR)<br>UART3 transmit/receive mode register (U3MR) |
| 032816           | UART3 transmitreceive mode register (USINR)                                        |
| 032916<br>032A16 |                                                                                    |
| 032A16<br>032B16 | UART3 transmit buffer register (U3TB)                                              |
| 032D16           | UART3 transmit/receive control register 0 (U3C0)                                   |
| 032D16           | UART3 transmit/receive control register 0 (03C0)                                   |
| 032E16           |                                                                                    |
| 032F16           | UART3 receive buffer register (U3RB)                                               |
| 033016           |                                                                                    |
| 033116           |                                                                                    |
| 033216           |                                                                                    |
| 033316           |                                                                                    |
| 033416           |                                                                                    |
| 033516           | UART2 special mode register 3 (U2SMR3)                                             |
| 033616           | UART2 special mode register 2 (U2SMR2)                                             |
| 033716           | UART2 special mode register (U2SMR)                                                |
| 033816           | UART2 transmit/receive mode register (U2MR)                                        |
| 033916           | UART2 bit rate generator (U2BRG)                                                   |
| 033A16           | UART2 transmit buffer register (U2TB)                                              |
| 033B16           | <b>.</b>                                                                           |
| 033C16           | UART2 transmit/receive control register 0 (U2C0)                                   |
| 033D16           | UART2 transmit/receive control register 1 (U2C1)                                   |
| 033E16           | UART2 receive buffer register (U2RB)                                               |
| 033F16           |                                                                                    |
|                  |                                                                                    |





| 034016           | Count start flag (TABSR)                                                                 |
|------------------|------------------------------------------------------------------------------------------|
| 034116           | Clock prescaler reset flag (CPSRF)                                                       |
| 034216           | One-shot start flag (ONSF)                                                               |
| 034316           | Trigger select register (TRGSR)                                                          |
| 034416           | Up-down flag (UDF)                                                                       |
| 034516           |                                                                                          |
| 034616           | Timer A0 (TA0)                                                                           |
| 034716<br>034816 |                                                                                          |
| 034016           | Timer A1 (TA1)                                                                           |
| 034A16           |                                                                                          |
| 034B16           | Timer A2 (TA2)                                                                           |
| 034C16           |                                                                                          |
| 034D16           | Timer A3 (TA3)                                                                           |
| 034E16           |                                                                                          |
| 034F16           | Timer A4 (TA4)                                                                           |
| 035016           | Timor B0 (TB0)                                                                           |
| 035116           | Timer B0 (TB0)                                                                           |
| 035216           | Timer B1 (TB1)                                                                           |
| 035316           |                                                                                          |
| 035416<br>035516 | Timer B2 (TB2)                                                                           |
| 035616           | Timer A0 mode register (TA0MR)                                                           |
| 035716           | Timer A1 mode register (TA0MR)                                                           |
| 035816           | Timer A2 mode register (TA2MR)                                                           |
| 035916           | Timer A3 mode register (TA3MR)                                                           |
| 035A16           | Timer A4 mode register (TA4MR)                                                           |
| 035B16           | Timer B0 mode register (TB0MR)                                                           |
| 035C16           | Timer B1 mode register (TB1MR)                                                           |
| 035D16           | Timer B2 mode register (TB2MR)                                                           |
| 035E16           |                                                                                          |
| 035F16           |                                                                                          |
| 036016<br>036116 | UART0 transmit/receive mode register (U0MR)                                              |
| 036216           | UART0 bit rate generator (U0BRG)                                                         |
| 036316           | UART0 transmit buffer register (U0TB)                                                    |
| 036416           | UART0 transmit/receive control register 0 (U0C0)                                         |
| 036516           | UART0 transmit/receive control register 1 (U0C1)                                         |
| 036616           |                                                                                          |
| 036716           | UART0 receive buffer register (U0RB)                                                     |
| 036816           | UART1 transmit/receive mode register (U1MR)                                              |
| 036916           | UART1 bit rate generator (U1BRG)                                                         |
| 036A16<br>036B16 | UART1 transmit buffer register (U1TB)                                                    |
| 036B16<br>036C16 | UART1 transmit/receive control register 0 (U1C0)                                         |
| 036D16           | UART1 transmit/receive control register 0 (01C0)                                         |
| 036E16           |                                                                                          |
| 036F16           | UART1 receive buffer register (U1RB)                                                     |
| 037016           | UART transmit/receive control register 2 (UCON2)                                         |
| 037116           |                                                                                          |
| 037216           |                                                                                          |
| 037316           |                                                                                          |
| 037416           |                                                                                          |
| 037516           |                                                                                          |
| 037616           | Flash memory control register 1 (FMR1) (Note)                                            |
| 037716           | Flash memory control register 0 (FMR0) (Note)                                            |
| 037816<br>037916 | DMA0 request cause select register (DM0SL)                                               |
| 037916<br>037A16 | DMA1 request cause select register (DM1SL)                                               |
| 037B16           | DMA2 request cause select register (DM2SL)<br>DMA3 request cause select register (DM3SL) |
| 037C16           |                                                                                          |
| 037D16           | CRC data register (CRCD)                                                                 |
| 037E16           | CRC input register (CRCIN)                                                               |
| 037F16           |                                                                                          |
|                  |                                                                                          |

| 038016           | A D register 0 (AD0)                                                 |
|------------------|----------------------------------------------------------------------|
| 038116           | A-D register 0 (AD0)                                                 |
| 038216           | A-D register 1 (AD1)                                                 |
| 038316           |                                                                      |
| 038416           | A-D register 2 (AD2)                                                 |
| 038516           |                                                                      |
| 038616           | A-D register 3 (AD3)                                                 |
| 038716<br>038816 |                                                                      |
| 038916           | A-D register 4 (AD4)                                                 |
| 038A16           |                                                                      |
| 038B16           | A-D register 5 (AD5)                                                 |
| 038C16           | A D register 6 (AD6)                                                 |
| 038D16           | A-D register 6 (AD6)                                                 |
| 038E16           | A-D register 7 (AD7)                                                 |
| 038F16           |                                                                      |
| 039016           |                                                                      |
| 039116           |                                                                      |
| 039216<br>039316 |                                                                      |
| 039316<br>039416 | A D control register 2 (ADCON2)                                      |
| 039516           | A-D control register 2 (ADCON2)                                      |
| 039616           | A-D control register 0 (ADCON0)                                      |
| 039716           | A-D control register 1 (ADCON1)                                      |
| 039816           | D-A register 0 (DA0)                                                 |
| 039916           |                                                                      |
| 039A16           | D-A register 1 (DA1)                                                 |
| 039B16           |                                                                      |
| 039C16<br>039D16 | D-A control register (DACON)                                         |
| 039E16           |                                                                      |
| 039F16           |                                                                      |
| 03A016           |                                                                      |
| 03A116           |                                                                      |
| 03A216           |                                                                      |
| 03A316           |                                                                      |
| 03A416           |                                                                      |
| 03A516<br>03A616 |                                                                      |
| 03A016           |                                                                      |
| 03A816           |                                                                      |
| 03A916           |                                                                      |
| 03AA16           |                                                                      |
| 03AB16           |                                                                      |
| 03AC16           |                                                                      |
| 03AD16           |                                                                      |
| 03AE16<br>03AF16 | Eurotion poloot register C(DSC)                                      |
| 03AF16<br>03B016 | Function select register C(PSC)<br>Function select register A0 (PS0) |
| 03B016           | Function select register A0 (PS0)                                    |
| 03B216           | Function select register B0 (PSL0)                                   |
| 03B316           | Function select register B1 (PSL1)                                   |
| 03B416           | Function select register A2 (PS2)                                    |
| 03B516           | Function select register A3 (PS3)                                    |
| 03B616           | Function select register B2 (PSL2)                                   |
| 03B716           | Function select register B3 (PSL3)                                   |
| 03B816           |                                                                      |
| 03B916<br>03BA16 |                                                                      |
| 03BA16<br>03BB16 |                                                                      |
| 03BC16           |                                                                      |
| 03BD16           |                                                                      |
| 03BE16           |                                                                      |
| 03BF16           |                                                                      |
|                  |                                                                      |

Note :This register exists in the flash memory version.

# Figure 2.1.5 Control register allocation 3



| 03C0H          | Port P6(P6)                                                          |
|----------------|----------------------------------------------------------------------|
| 03C1H          | Port P7(P7)                                                          |
| 03C2H          | Port P6 direction register (PD6)                                     |
| 03C3H          | Port P7 direction register (PD7)                                     |
| 03C4H          | Port P8(P8)                                                          |
| 03C5H          | Port P9(P9)                                                          |
| 03C6H          | Port P8 direction register (PD8)                                     |
| 03C7H          | Port P9 direction register (PD9)                                     |
| 03C8H<br>03C9H | Port P10(P10)                                                        |
| 03CAH          | Port P10 direction register (PD10)                                   |
| 03CBH          |                                                                      |
| 03CCH          |                                                                      |
| 03CDH          |                                                                      |
| 03CEH          |                                                                      |
| 03CFH          |                                                                      |
| 03D0H          |                                                                      |
| 03D1H          |                                                                      |
| 03D2H          |                                                                      |
| 03D3H          |                                                                      |
| 03D4H          |                                                                      |
| 03D5H          |                                                                      |
| 03D6H<br>03D7H |                                                                      |
| 03D7H<br>03D8H |                                                                      |
| 03D9H          |                                                                      |
| 03DAH          | Pull-up control register 2(PUR2)                                     |
| 03DBH          | Pull-up control register 3(PUR3)                                     |
| 03DCH          |                                                                      |
| 03DDH          |                                                                      |
| 03DEH          |                                                                      |
| 03DFH          |                                                                      |
| 03E0H          | Port P0(P0)                                                          |
| 03E1H          | Port P1(P1)                                                          |
| 03E2H          | Port P0 direction register (PD0)<br>Port P1 direction register (PD1) |
| 03E3H<br>03E4H | Port P2(P2)                                                          |
| 03E5H          | Port P3(P3)                                                          |
| 03E6H          | Port P2 direction register (PD2)                                     |
| 03E7H          | Port P3 direction register (PD3)                                     |
| 03E8H          | Port P4(P4)                                                          |
| 03E9H          | Port P5(P5)                                                          |
| 03EAH          | Port P4 direction register (PD4)                                     |
| 03EBH          | Port P5 direction register (PD5)                                     |
| 03ECH          |                                                                      |
| 03EDH          |                                                                      |
| 03EEH          |                                                                      |
| 03EFH<br>03F0H | Pull-up control register 0(PUR0)                                     |
| 03F0H<br>03F1H | Pull-up control register 0(POR0)                                     |
| 03F2H          |                                                                      |
| 03F3H          |                                                                      |
| 03F4H          |                                                                      |
| 03F5H          |                                                                      |
| 03F6H          |                                                                      |
| 03F7H          |                                                                      |
| 03F8H          |                                                                      |
| 03F9H          |                                                                      |
| 03FAH          |                                                                      |
| 03FBH          |                                                                      |
| 03FCH          |                                                                      |
| 03FDH<br>03FEH |                                                                      |
| 03FEH<br>03FFH | Port control register (PCR)                                          |
| 001111         |                                                                      |
| Note:          | Address 03C9H, 03CBH to 03D3H area is for future plan.               |

Note: Address 03C9H, 03CBH to 03D3H area is for future plan. Must set "FF<sub>16</sub>" to address 03CBH, 03CEH, 03CFH, 03D2H, 03D3H at initial setting.

### Figure 2.1.6 Control register allocation 4



#### **Determination of Operation Mode**

The operation modes of the M16C/80 group are determined by the CNVSS pin, processor mode register 0 (address 000004H), and bits 0 and 1.

Figure 2.1.7 shows the configuration of processor mode register 0.

#### Processor mode register 0 (Note 1)

| b7 b6 b5 b4 b3 b2 b1 b0 | Symbo<br>PM0                    | ol Address<br>0004 <sub>16</sub>                           | When reset<br><sup>80</sup> 16                                                                                                                                 |                   |   |
|-------------------------|---------------------------------|------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|---|
|                         | Bit symbol                      | Bit name                                                   | Function                                                                                                                                                       | R                 | W |
|                         | PM00                            | Processor mode bit                                         | b1 b0<br>0 0 : Single-chip mode                                                                                                                                | 0                 | 0 |
| L                       | PM01                            |                                                            | 0 1 : Memory expansion mode<br>1 0 : Inhibited<br>1 1 : Microprocessor mode                                                                                    | 0                 | 0 |
|                         | PM02                            | R/W mode select bit(<br>Note 7)                            | 0 : <u>RD</u> , <u>BHE , WR</u><br>1 : RD , WRH , WRL                                                                                                          | 0                 | 0 |
| L                       | PM03                            | Software reset bit                                         | The device is reset when this bit is set to "1".<br>The value of this bit is "0" when read.                                                                    | 0                 | 0 |
|                         | PM04                            | Multiplexed bus space                                      | b4 b5<br>0 0 : Multiplexed bus is not used<br>0 1 : Allocated to CS2 space                                                                                     | 0                 | 0 |
|                         | PM05                            | select bit ( Note 3 )                                      | 1 0 : Allocated to CS2 space<br>1 1 : Allocated to entire space (Note 4)                                                                                       | 0                 | 0 |
|                         | Reserved bit                    |                                                            | Must always be set to "0".                                                                                                                                     | 0                 | 0 |
| l                       | PM07                            | BCLK output disable bit<br>( Note 5 )                      | 0 : BCLK is output ( Note 6 )<br>1 : Function set by bit 0,1 of system clock<br>control register 0                                                             | 0                 | 0 |
| Note 2 : If t<br>(F     | he Vcc voltage<br>M00 is set to | e is applied to the CNVss ,t<br>"1" and PM07 is set to "0" | 6) to "1" when writeing new value to this register<br>he value of this register when reset when reset i<br>.)<br>sion modes 1.2 and 3 Do not use multiplex bus | s 03 <sub>1</sub> |   |

Note 3 : Valid in microprocessor and memory expansion modes 1,2 and 3.Do not use multiplex bus when mode 0 is selected.Do not set to allocated to CS2 space when mode 2 is selected.

Note 4 : After the reset has been released the M16C/80 group MCU operates using the separate bus. As a result,in microprocessor mode,you cannot select the full CS space multiplex bus.

When you select the full CS space multiplex bus in memory expansion mode, the address bus operates with 64 K bytes boundance for each chip select.

Mode 0 : Multiplexed bus cannot be used. Mode 1 : CS0 to CS2 when you select full CS space. Mode 2 : CS0 to CS3 when you select full CS space. Mode 3 : CS0 to CS3 when you select full CS space. Note 5 : No BCLK is output in single chip mode even when "0" is set in PM07.When stopping clock output in microprocessor or momony comparison mode make the following settings:BM07="4" bit 0 (CM00) microprocessor or memory expansion mode, make the following settings: PM07="1", bit 0 ( CM00 ) and bit 1( CM01 ) of system clock control register 0 = "0"."L" is now output from P53.

Note 6 : See the data sheet for BCLK.

Note 7 : When using 16-bit bus width in DRAM controler, set this bit to "1".

#### Figure 2.1.7 Processor mode register 0

# 2.1.3 Fixed Vector Area

The M16C/80 group fixed vector area consists of addresses FFFE00H to FFFFFH.

Addresses FFFE00H to FFFFDBH in this area constitute a special page vector table. This table is used to store the start addresses of subroutines and jump addresses, so that subroutine call and jump instructions can be executed using two bytes, helping to reduce the number of program steps. Addresses FFFFDCH to FFFFFH in the fixed vector area constitute a fixed interrupt vector table for reset and NMI. This table is used to store the start addresses of interrupt routines. An interrupt vector table for timer interrupts, etc. can be set at any desired address by an internal register (INTB). For details, refer to the section dealing with interrupts in Chapter 4.



### Memory Mapping in Fixed Vector Area



# 2.2 Register Set

The following explains the general registers, high-speed interrupt registers, and DMAC-related registers included in the M16C/80 series CPU core.

### **Register Structure**

Figure 2.2.1 shows the register structure of the M16C/80 series CPU core. Eight registers--R0, R1, R2, R3, A0, A1, FB, and SB--are available in two sets each. The following shows the function of each register.

#### **General registers**

(1) Data registers (R0, R1, R2, and R3)

These registers consist of 16 bits each and are used mainly for data transfer and arithmetic/ logic operations.

Registers R0 and R1 can be used separately for upper bytes (R0H, R1H) and lower bytes (R0L, R1L) as 8-bit data registers. For some instructions, registers R2 and R0 and registers R3 and R1 can be combined for use as 32-bit data registers (R2R0, R3R1), respectively.

(2) Address registers (A0 and A1)

These registers consist of 24 bits, and have the functions equivalent to those of the data registers. In addition, these registers are used in address register indirect addressing and address register relative addressing.

- (3) Frame base register (FB)This register consists of 24 bits, and is used in FB relative addressing.
- (4) Static base register (SB) This register consists of 24 bits, and is used in SB relative addressing.
- (5) Program counter (PC)This counter consists of 24 bits, indicating the address of an instruction to be executed.
- (6) Interrupt table register (INTB) This register consists of 24 bits, indicating the start address of an interrupt vector table.
- (7) Stack pointers (USP or ISP)
  There are two stack pointers: a user stack pointer (USP) and an interrupt stack pointer (ISP).
  Both of these pointers consist of 24 bits.
  The stack pointers used (USP or ISP) are switched over by a stack pointer select flag (U flag).
  The U flag is assigned to bit 7 of the flag register (FLG).
  Set odd numbers in USP and ISP. Execution efficiency is better when odd numbers are set.
- (8) Flag register (FLG)This register consists of 11 bits, each of which is used as a flag.



#### High-speed interrupt registers

(9) Save flag register (SVF)

This register consists of 16 bits and is used to save the flag register when a high-speed interrupt is generated.

(10) Save PC register (SVP)

This register consists of 24 bits and is used to save the program counter when a high-speed interrupt is generated.

(11) Vector register (VCT) This register consists of 24 bits and is used to indicate the jump address when a high-speed interrupt is generated.

#### **DMAC related registers**

- (12) DMA mode registers (DMD0 and DMD1) These registers consist of 8 bits and are used to set the transfer mode,etc.for DMA.
- (13) DMA transfer count registers (DCT0 and DCT1) These registers consist of 16 bits and are used to set the number of DMA transfers performed.
- (14) DMA transfer count reload registers (DRC0 and DRC1) These registers consist of 16 bits and are used to reload the DMA transfer count registers.
- (15) DMA memory address registers (DMA0 and DMA1) These registers consist of 24 bits and are used to set a memory address at the source or destination of DMA transfer.
- (16) DMA SFR address registers (DSA0 and DSA1) These registers consist of 24 bits and are used to set a fixed address at the source or destination of DMA transfer.
- (17) DMA memory address reload registers (DRA0 and DRA1)

# RENESAS

| Data register       | Register bank 0                    |
|---------------------|------------------------------------|
| b31 b15             | Begister bank 1                    |
| R2 R0H              | ROL                                |
| R3 R1H              |                                    |
|                     |                                    |
| R2                  |                                    |
| R3                  |                                    |
| Addross register    |                                    |
| Address register    |                                    |
| A0                  |                                    |
| A1                  |                                    |
|                     |                                    |
| Frame base regist   | er                                 |
| b23                 | b0                                 |
| FB                  |                                    |
| Static base registe |                                    |
|                     |                                    |
| SB 5                |                                    |
|                     |                                    |
|                     |                                    |
| b15 b0              |                                    |
|                     | ag register                        |
| PC Pr               | ogram counter                      |
|                     | terrupt table register             |
|                     | ser stack pointer                  |
| ISP Int             | terrupt stack pointer              |
| b15 b0              |                                    |
|                     | ag save register                   |
|                     | C save register                    |
|                     | ector register                     |
|                     |                                    |
| b15 DMD0            | DMA mode register                  |
|                     |                                    |
| DCT1                | DMA transfer cout register         |
|                     |                                    |
| DRC1                | DMA transfer count reload register |
|                     | DMA memory address register        |
| DIMAT               | DMA memory address register        |
| DSA0                | DMA SFR address register           |
| DSA1                | Jun Or Naddress register           |
| DRA0                | DMA memory address reload register |
| DRA1                |                                    |
|                     |                                    |



## Flag Register (FLG)

Figure 2.2.2 shows the bit configuration of the flag register (FLG). The function of each flag is described below.

#### • Bit 0: Carry flag (C flag)

This bit holds a carry or borrow that has occurred in an arithmetic/logic operation or a bit that has been shifted out.

#### • Bit 1: Debug flag (D flag)

This flag enables a single-step interrupt. When this flag is 1, a single-step interrupt is generated after instruction execution. When the interrupt is accepted, this flag is cleared to 0.

#### • Bit 2: Zero flag (Z flag)

This flag is set to 1 when the operation resulted in 0; otherwise, the flag is 0.

#### • Bit 3: Sign flag (S flag)

This flag is set to 1 when the operation resulted in an negative number. The flag is 0 when the result is positive.

#### • Bit 4: Register bank specifying flag (B flag)

This flag chooses a register bank. Register bank 0 is selected when the flag is 0. Register bank 1 is selected when the flag is 1.

#### • Bit 5: Overflow flag (O flag)

This flag is set to 1 when the operation resulted in an overflow.

#### • Bit 6: Interrupt enable flag (I flag)

This flag enables a maskable interrupt. The interrupt is enabled when the flag is 1, and is disabled when the flag is 0. This flag is cleared to 0 when the interrupt is accepted.

• Bit 7: Stack pointer specifying flag (U flag)

The user stack pointer (USP) is selected when this flag is 1. The interrupt stack pointer (ISP) is selected when the flag is 0.

This flag is cleared to 0 when a hardware interrupt is accepted or an INT instruction of software interrupt numbers 0 to 31 is executed.

#### • Bits 8 to 11: Reserved.

#### • Bits 12 to 14: Processor interrupt priority level (IPL)

The processor interrupt priority level (IPL) consists of three bits, for specification of up to eight processor interrupt priority levels from level 0 to level 7. If the priority level of a requested interrupt is greater than the processor interrupt priority

level(IPL), the interrupt is enabled.

• Bit 15: Reserved.



RENESAS



# **Register Status after Reset is Cleared**

Table 2.2.1 lists the status of each register after a reset is cleared<sup>(Note)</sup>.

#### Table 2.2.1 Register Status after Reset Cleared

| Register name                                 | Status after a reset is cleared |
|-----------------------------------------------|---------------------------------|
| Data register(R0/R1/R2/R3)                    | 0000H                           |
| Address register(A0/A1)                       | 000000H                         |
| Static base register(SB)                      | 000000H                         |
| Flame base register(FB)                       | 000000H                         |
| Interrupt table register(INTB)                | 000000H                         |
| User stack pointer(USP)                       | 000000H                         |
| Interrupt stack pointer(ISP)                  | 000000H                         |
| Flag register(FLG)                            | 0000H                           |
| DMA mode register(DMD0/DMD1)                  | 00H                             |
| DMA transfer count register(DCT0/DCT1)        | Undefined.                      |
| DMA transfer count reload register(DRC0/DRC1) | Undefined.                      |
| DMA memory address register(DMA0/DMA1)        | Undefined.                      |
| DMA SFR address register(DSA0/DSA1)           | Undefined.                      |
| DMA memory address reload register(DRA0/DRA1) | Undefined.                      |

Note: For the control register status in the SFR area after a reset is cleared, refer to the M16C/80 group data sheets and user's manuals.



# 2.3 Data Types

There are four data types handled by the M16C/80 series: integer, decimal (BCD), string, and bit. This section describes these data types.

#### Integer

| An integer may be a signed or represented by a 2's compleme | an unsigned integer. A negative value of a signed integer is ent. |
|-------------------------------------------------------------|-------------------------------------------------------------------|
| Signed byte (8-bit) integer                                 | ьт ьо<br>S                                                        |
| Unsigned byte (8-bit) integer                               |                                                                   |
| Signed word (16-bit) integer                                | ь15 ь0<br>S                                                       |
| Unsigned word (16-bit) integer                              |                                                                   |
| Signed long word (32-bit) integer                           | b31 b0<br>S                                                       |
| Unsigned long word (32-bit) integer                         |                                                                   |
| Figure 2.3.1 Integer data                                   | S: Sign bit                                                       |
| i igai o ziorr integer data                                 |                                                                   |

# **Decimal (BCD)**

| The BCD code is handl<br>This type of data can be<br>DSBB, and DSUB. | ed in packed format.<br>used in four kinds of decimal arithmetic instructions: DADC, DADD, |  |
|----------------------------------------------------------------------|--------------------------------------------------------------------------------------------|--|
| 1-byte packed format<br>(2 digits)                                   |                                                                                            |  |
| 2-byte packed format (4 digits)                                      |                                                                                            |  |
| Figure 2.3.2 Decimal                                                 | lata                                                                                       |  |

# RENESAS

## String

A string is a block of data comprised of a consecutive number of 1-byte or 1-word (16-bit) data. This type of data can be used in seven kinds of string instructions:SMOVB,SMOVF,SSTR,SCMPU,SIN and SOUT.



Figure 2.3.3 String data

#### Bit

Bit can be used in 14 kinds of bit instructions, including BCLR, BSET, BTST, and BNTST. Bits in each register are specified by a register name and a bit number, 0 to 15. Memory bits are specified by a different method in a different range depending on the addressing mode used. For details, refer to Section 2.5.4, "Bit Instruction Addressing".

A0 \_\_\_\_\_\_ 2,A0 (A0 register, bit 2)(Note)

#### Figure 2.3.4 Specification of register bits



Note : A0 and A1 register can be specified by the lower 8 bit.

# 2.4 Data Arrangement

The M16C/80 series can handle nibble (4-bit) and byte (8-bit) data efficiently. This section explains the data arrangements that can be handled by the M16C/80 series.

## Data Arrangement in Register

Figure 2.4.1 shows the relationship between the data sizes and the bit numbers of a register. As shown below, the bit number of the least significant bit (LSB) is 0. The bit number of the most significant bit (MSB) varies with the data sizes handled.





## **Data Arrangement in Memory**

Figure 2.4.2 shows the data arrangement in the M16C/80 series memory. Data is arranged in memory in units of 8 bits as shown below. A word (16 bits) is divided between the lower byte and the upper byte, with the lower byte, DATA(L), placed in a smaller address location. Similarly, addresses (24 bits) and long words (32 bits) are located in memory beginning with the lower byte, DATA(L) or DATA(LL).



# 2.5 Addressing Modes

This section explains the M16C/80 series addressing.

- The four types of addressing modes shown below are available.
- (1) General instruction addressing
  - The entire address space from address 000000H to FFFFFH is accessed.
- (2) Indirect instruction addressing The entire address space from address 000000H to FFFFFH is accessed.
- (3) Special instruction addressing The entire address space from 000000H to FFFFFH is accessed and control registers.
- (4) Bit instruction addressing The entire address space from address 000000H to FFFFFH is accessed in units of bits.

### List of Addressing Modes

All addressing modes are summarized in Table 2.5.1 and Table 2.5.2 below.

#### Table 2.5.1 Addressing Modes of M16C/80 Series 1

| Item                                             | Content                                                                  |                                                       |  |  |
|--------------------------------------------------|--------------------------------------------------------------------------|-------------------------------------------------------|--|--|
| ddressing mode                                   | General instruction                                                      | Indirect instruction                                  |  |  |
| Immediate                                        | imm:8/16/32 bits                                                         | X                                                     |  |  |
| Register direct                                  | Data register and address registers only                                 | Х                                                     |  |  |
| Control register direct                          | x                                                                        | X                                                     |  |  |
| Absolute                                         | abs:16 bits (0 to FFFFH)<br>24 bits (0 to FFFFFFH)                       | X                                                     |  |  |
| Absolute indirect                                | X                                                                        | [abs : 16/24 bits] (0 to FFFFFH)                      |  |  |
| Address register indirect                        | [A0] or [A1] without disp                                                | Х                                                     |  |  |
| Two-stage<br>address register indirect           | X                                                                        | [[A0]] or[[A1]] without disp (0 to FFFFFH)            |  |  |
| Address register relative                        | [A0] or [A1] dsp : 8/16/24 bits                                          | х                                                     |  |  |
| Address register<br>relative indirect            | X                                                                        | [dsp:8/16/24[A0] ] or [dsp:8/16/24[A1] ] (0 to FFFFFH |  |  |
| SB relative<br>and FB relative                   | dsp:8[SB]<br>dsp:16[SB]<br>dsp:8/16 bits(0 to 255 / 0 to 65534)          | x                                                     |  |  |
|                                                  | dsp:8[FB]<br>dsp:16[FB]<br>dsp:8/16 bits(-128 to +127 / 32768 to +32767) | X                                                     |  |  |
| SB relative indirect<br>and FB relative indirect | x                                                                        | [dsp:8/16[SB]] (0 to FFFFFH)                          |  |  |
|                                                  | Х                                                                        | [dsp:8/16[FB]] (0 to FFFFFH)                          |  |  |
| Stack pointer relative                           | dsp:8[SP]<br>dsp : 8 bits (-128 to +127) *MOV instruction only           | x                                                     |  |  |
| Program counter relative                         | x                                                                        | X                                                     |  |  |
| FLG direct                                       | X                                                                        | X                                                     |  |  |

| Item                                          | Content                                                                                                                                                                                          |                                                                      |  |
|-----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|--|
| ddressing mode                                | Special instruction                                                                                                                                                                              | Bit instruction                                                      |  |
| Immediate                                     | X                                                                                                                                                                                                | Х                                                                    |  |
| Register direct                               | X                                                                                                                                                                                                | R0L/R0H/R1L/R1H/A0/A1 only                                           |  |
| Control register direct                       | INTB,ISP,SP,DMD0 etc.control registeronly                                                                                                                                                        | X                                                                    |  |
| Absolute                                      | X                                                                                                                                                                                                | base:19/27 bits (0 to FFFFH / 0 to 0FFFFFFH)                         |  |
| Absolute indirect                             | X                                                                                                                                                                                                | x                                                                    |  |
| Address register indirect                     | x                                                                                                                                                                                                | bit,[A0] or bit,[A1](0H to 0FFFFFH)<br>bit:0 to 7                    |  |
| Two-stage<br>address register indirect        | X                                                                                                                                                                                                | Х                                                                    |  |
| Address register relative                     | Х                                                                                                                                                                                                | bit,base[A0] or bit,base[A1]<br>base:11/19/27                        |  |
| Address register<br>relative indirect         | x                                                                                                                                                                                                | X                                                                    |  |
| SB relative<br>and FB relative                | X                                                                                                                                                                                                | bit,base:11[SB] (0H to FFH)<br>bit,base:19[SB] (0H to FFFFH)         |  |
|                                               | х                                                                                                                                                                                                | bit,base:11[FB] (-128 to +127)<br>bit,base:19[FB] (-32768 to +32767) |  |
| SB relative indirect and FB relative indirect | X                                                                                                                                                                                                | Х                                                                    |  |
|                                               | x                                                                                                                                                                                                | х                                                                    |  |
| Stack pointer relative                        | X                                                                                                                                                                                                | x                                                                    |  |
| Program counter relative                      | label: .S: +0 to +7(JMP instruction only)<br>.B: -128 to +127(JMP,JSR instruction only)<br>.W: -32768 to +32767(JMP,JSR instruction only)<br>.without length: -127 to +128(Jcn instruction only) | X                                                                    |  |
| FLG direct                                    | X                                                                                                                                                                                                | U, I, O, B, S, Z, D, C flag *FSET,FCLR instruction or                |  |

# Table 2.5.2 Addressing Modes of M16C/80 Series 2



## 2.5.1 General Instruction Addressing

This section explains each addressing in the general instruction addressing mode.

#### Immediate

```
The immediate indicated by #IMM is the subject on which operation is performed. Add a # before the immediate.
Symbol: #IMM, #IMM8, #IMM16, #IMM32
Example: #123 (decimal)
#7DH (hexadecimal)
#01111011B (binary)
```

#### Absolute



#### **Register direct**

A specified register is the subject on which operation is performed. However, only the data and address registers can be used here. Symbol: 8 bits R0L, R0H, R1L, R1H 16 bits R0, R1, R2, R3, A0, A1 32 bits R2R0, R3R1



## Address Register Indirect

The value of an address register is the effective address to be operated on. The range of effective addresses is 000000H to FFFFFH. Symbol: [A0], [A1] Example: MOV.B #12H, [A0]  $A_0 \underbrace{1000H}_{001000H} \underbrace{12H}_{12H}$ FFFFFFH



## Address Register Relative

The value of an address register plus a displacement (dsp)<sup>(Note)</sup> is the effective address to be operated on. The range of effective addresses is 000000H to FFFFFH. If the addition result exceeds FFFFFH, the most significant bits above and including bit 25 are ignored and the address returns to 000000H.

Symbol: dsp:8[A0], dsp:16[A0], dsp:24[A0], dsp:8[A1],dsp:16[A1],dsp24[A1]

(1) When dsp is handled as a displacement Example: MOV.B #34H,5[A0] 000000H ►001000H Relative address range A0 001000H + 5H = 001005Hdsp:8 0 to FFH dsp:16 0 to FFFFH 34H 001005H dsp:24 0 to FFFFFH FFFFFFH Figure 2.5.3 Address register relative addressing 1 (2) When address register (A0) is handled as a displacement Example: MOV.B #56H,1234H[A0] 000000H ١ 001234H A0 Relative address range 001234H + 000005H = 001239H dsp:8 0 to FFH ▶ 001239⊦ 56H dsp:16 0 to FFFFH dsp:24 0 to FFFFFH FFFFFFH Figure 2.5.4 Address register relative addressing 2 (3) When the addition result exceeds 0FFFH Example: MOV.B #56H,1234H[A0] 000000H 023456⊢ AO 56H 123456H F00000H 1023456 Relative address range dsp:8 0 to FFH ► 123456H dsp:16 0 to FFFFH dsp:24 0 to FFFFFH Ignored FFFFF Figure 2.5.5 Address register relative addressing 3

Note: The displacement (dsp) refers to a displacement from the reference address. In this manual, 8-bit dsp is expressed as dsp:8, 16-bit dsp is expressed as dsp:16, and 24-bit dsp is expressed as dsp:24



#### **SB** Relative

The address indicated by the content of static base register(SB) plus the value indicated by displacement(dsp) -added not including the sign bits- constitutes the effective address to be operated on. The range of effective addresses is 000000H to FFFFFFH. However, if the addition resulted in exceeding FFFFFFH, the bits above bit 25 are ignored, and the address returns to 000000H.

Symbol: dsp:8[SB], dsp:16[SB] Example: MOV.B #12H,5[SB]



Figure 2.5.6 SB relative addressing

#### **FB** Relative

The address indicated by the content of frame base register(FB) plus the value indicated by displacement(dsp) -added not including the sign bits- constitutes the effective address to be operated on. The range of effective addresses is 000000H to FFFFFFH. However, if the addition resulted in exceeding 000000H to FFFFFFH, the bits above bit 25 are ignored, and the address returns to 000000H or FFFFFFH.

Symbol: dsp:8[FB]



Figure 2.5.8 FB relative addressing 2

FFFFFFH

Effective address

## Column Difference between SB Relative and FB Relative

In SB relative addressing, the address indicated by the SB register content and the value indicated by dsp are added not including the sign and the result of addition is the effective address to be operated on. The relative range is 0 to +255 (FFH) for dsp: 8[SB], and 0 to +65535 (FFFFH) for dsp: 16[SB].

In FB relative addressing, dsp is added to or subtracted from the address indicated by the FB register content and the result of addition or subtraction is the effective address to be operated on. The relative range is -128 to +127 (80H to 7FH) for dsp: 8[FB], and -32768 to +32767 (8000H to 7FFH) for dsp: 16[FB]. FB relative allows accessing memory locations in the negative direction. The dsp used for this addressing can be 8 bits or 16 bits.


## **Column Application Example of SB Relative**

SB relative addressing can be applied for the specific data table of each subroutine as shown in Figure 2.5.10. Although the data necessary to run each subroutine must be switched over when calling the subroutine, use of SB relative addressing helps to accomplish this switchover by only rewriting the SB register.



Figure 2.5.10 Application example of SB relative addressing

## **Column Application Example of FB Relative**

FB relative addressing can be used for the stack frame that is created when calling a function, as shown in Figure 2.5.11. Since the local variable area in the stack frame is located in the negative direction of addresses, FB relative addressing is needed because it allows for access in both positive and negative directions from the base.





## Stack Pointer Relative (SP Relative)





## Column Relative Address Ranges of Relative Addressing

The relative address ranges of relative addressing are summarized in Table 2.5.3.

#### Table 2.5.3 Relative Address Ranges of Relative Addressing

| Addressing mode                | Descriptive form                                   | Relative range                                                                                  |
|--------------------------------|----------------------------------------------------|-------------------------------------------------------------------------------------------------|
| Address register relative      | dsp:8[An]<br>dsp:16[An]<br>dsp:24[An]              | 0 to 255(FFH)<br>0 to 65535(FFFFH)<br>0 to 16777215(FFFFFFH)                                    |
| SB relative<br>and FB relative | dsp:8[SB]<br>dsp:16[SB]<br>dsp:8[FB]<br>dsp:16[FB] | 0 to 255(0FFH)<br>0 to 65535(0FFFH)<br>-128(80H) to +127(7FH)<br>-32768(8000H) to +32767(7FFFH) |
| Stack pointer relative         | dsp:8[SP]                                          | -128(80H) to +127(7FH)                                                                          |

## 2.5.2 Indirect instruction Addressing

The Indirect instruction addressing accesses an area from address 000000H to FFFFFH. This section explains each addressing in the indirect instruction addressing mode.

#### Absolute indirect

The 4-bytes value indicated by absolute addressing constitutes the effective address to be operated on. The effective address range is 000000H to FFFFFH.

Symbol: [abs16] or [abs24] Example: MOV.B [001000H],R0L



#### Two-stage address register indirect

The 4-bytes value indicated by address register(A0/A1) indirect constitutes the effective address to be operated on. The effective address range is 000000H to FFFFFH.

Symbol: [[A0]] or [[A1]] Example: MOV.B [[A0]],R0L





## Address register relative indirect

The 4-bytes value indicated by address register relative constitutes the effective address to be operated on. The effective address range is 000000H to FFFFFH. Symbol: [dsp:8[A0]],[dsp:8[A1]],[dsp:16[A0]],[dsp:16[A1]],[dsp:24[A0]],or[dsp:24[A1]] Example: MOV.B [5[A0]],ROL





## **SB** relative indirect





## FB relative indirect



## 2.5.3 Special Instruction Addressing

The Special Instruction addressing accesses an area from address 000000H to FFFFFH and control registers. This section explains each addressing in the special instruction addressing mode.

## Control register direct

## Program counter relative

When the jump length specifier (.length) is (.S) ... the base address plus the value indicated by displacement(dsp) -added not including the sign bit- constitutes the effective address. This addressing can be used in JMP instruction.

(1)When the jump length specifier (.length) is (.S)

Symbol:label (PC+2  $\leq$  label  $\leq$  PC+9)



#### Figure 2.5.21 Program counter relative addressing 1

When the jump length specifier (.length) is (.B) or (.W) ... the base address plus the value indicated by displacement(dsp) -added including the sign bits- constitutes the effective address. This addressing can be used in JMP and JSR instructions.

(2)When the jump length specifier (.length) is (.B)

Symbol:label (PC-128  $\leq$  label  $\leq$  PC+127)



Figure 2.5.22 Program counter relative addressing 2





#### Figure 2.5.23 Program counter relative addressing 3

If the jump distance specifier(.length) is omitted ,the assembler chooses the optimum specifier. And if the addition resulted in exceeding 000000H to FFFFFH the bits above bit 25 are ignored,and the address returns to 000000H or FFFFFH.

## 2.5.4 Bit Instruction Addressing

The Bit Instruction addressing accesses an area from address 000000H to FFFFFFH. This addressing can be used in the bit instructions. This section explains each addressing in the bit instruction addressing mode.

## Absolute





## **Register direct**

The specified register bit is the object to be operated on. For the bit position(bit) you can specify 0 to 7. For the address register(A0,A1), you can specify 8 low-order bits. Symbol: bit,R0L, bit,R0H, bit,R1L, bit,R1H, bit,A0, or bit,A1 Example:BCLR 6,R0L



Figure 2.5.26 Bit instruction register direct addressing

## FLG Direct

The specified flag is the object to be operated on. This addressing can be used in FCLR and FSET instructions. The bit positions that can be specified here are only the 8 low-order bits of the FLG register. Symbol: U, I, O, B, S, Z, D, C Example: FSET U FLG b15 FLG b15 The U flag is seted.

Figure 2.5.27 Bit instruction FLG direct addressing



## **Address Register Indirect**

The bit that is as much away from bit 0 at address indicated by address register(A0/A1) as the number of bits is the object to be operated on. Bits at addresses 000000H to FFFFFFH can be the object to be operated on. For the bit position (bit) you can specify 0 to 7. Symbol: bit,[A0] or bit,[A1] Example: BCLR 5,[A0]

## **Address Register Relative**

The bit that is as much away from bit 0 at the address indicated by base -added not including the sign bits- as the number of bits indicated by address register(A0/A1) is the object to be operated on. The effective address range is 000000H to FFFFFH.However, if the address of the bit to be operated on exceeds FFFFFH, the bits above bit 25 are ignored and address returns 000000H. The address range that can be specified by bit,base:11, bit,base:19, and bit,base:27 respectively are 256 bytes,65536 bytes, and 16777216 bytes from address register(A0/A1) value.

Symbol:bit,base:11[A0], bit,base:11[A1], bit,base:19[A0], bit,base:19[A1], bit,base:27[A0],or bit,base:27[A1]





## **SB** Relative

In this mode, the address is referenced to the value indicated by the SB register. The value of the SB register has base added without a sign. The resulting value indicates the reference address, so operation is performed on the bit that is away from bit 0 at that address by a number of bits indicated by bit.

The address range the can be specified by bit,base:11, and bit,base:19 respectively are 256 bytes,and 65536 bytes form the static base register(SB) value. However,if the address of the bit to be operated on exceeds FFFFFH,the bits above bit 25 are ignored and the address returns to 000000H.

Symbol:bit,base:11[SB] or bit,base:119[SB]

Note: bit,base:11 [SB] : One bit in an area of up to 256 bytes can be specified.

bit,base:19 [SB] : One bit in an area of up to 64 K bytes can be specified.





Figure 2.5.30 Bit instruction SB relative addressing



## **FB** Relative

In this mode, the address is referenced to the value indicated by the FB register. The value of the FB register has base added with the sign included. The resulting value indicates the reference address, so operation is performed on the bit that is away from bit 0 at that address by a number of bits indicated by bit.

Symbol: bit,base:11[FB ] or bit,base:19[FB] Example: BCLR 5,-8[FB]



# 2.6 Instruction Set

RENESAS

This section explains the instruction set of the M16C/80 series. The instruction set is summarized by function in list form. In addition, some characteristic instructions among the instruction set are explained in detail.

The table below shows the symbols used in the list and explains their meanings.

| Symbol                     | Meaning                                                                                |
|----------------------------|----------------------------------------------------------------------------------------|
| src                        | Operand that does not store processing result.                                         |
| dest                       | Operand that stores processing result.                                                 |
| label                      | Operand that means an address.                                                         |
| abs16/24                   | Absolute value.(16 bits or 24 bits)                                                    |
| abs20                      | 20-bit absolute value.                                                                 |
| dsp:8/16/24                | Displacement.(8 bits, 16 bits, or 24 bits)                                             |
| dsp:16                     | 16-bit displacement.                                                                   |
| #IMM/4/8/16/24/32          | Immediate value.(8 bits, 16 bits, 24 bits, or 32 bits)                                 |
| .size                      | Size specifier.(.B or .W)                                                              |
| .length                    | Jump distance specifier.(.S, .B, .W, or .A)                                            |
| $\leftarrow$               | Transfers in the direction of arrow.                                                   |
| +                          | Add.                                                                                   |
| -                          | Subtract.                                                                              |
| *                          | Multiply.                                                                              |
| /                          | Divide.                                                                                |
| &                          | Logical AND.                                                                           |
| 1                          | Logical OR.                                                                            |
| ^                          | Exclusive OR.                                                                          |
| —                          | Negate.                                                                                |
|                            | Absolute value.                                                                        |
| EXT()                      | Extend sign in ( ).                                                                    |
| U,I,O,B,S,Z,D,C            | Flag name.                                                                             |
| R0L,R0H,R1,R1H             | 8-bit register name.                                                                   |
| R0,R1,R2,R3,A0,A1          | 16-bit register name.                                                                  |
| R2R0,R3R1,A1A0             | 32-bit register name.                                                                  |
| SB,FB,SP,PC                | Register name.                                                                         |
| MOV <i>Dir</i> ,BMCnd,JCnd | Dir(direction) and Cnd(condition) mnemonics are shown in italic.                       |
| JGEU/C,JEQ/Z               | Indecate that JGEU/C is written as JGEU or JC, and that JEQ/Z is wrriten as JEQ or JZ. |
| INDEX type                 | Mnemonics of type(modifier type) are shown in italic.                                  |
| "O"                        | (Addressing) Can be used.                                                              |
|                            | (Flag change) Flag changes according to execution result.                              |
| "_"                        | (Flag change) Flag does not change.                                                    |



## 2.6.1 Instruction Description

This section explains the format in which M16C/80 instructions are written.

## Format of instruction description



## Figure 2.6.1 Format of instruction description

| Mnemonic<br>Size specifier | : Indicates the operation performed by the instruction.<br>: Specifies the data size to be operated on by the mnemonic.                     |
|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Branch distance specifier  | : Specifies the distance to the target address of a branch instruction or subroutine call instruction. (Normally omitted.)                  |
| Format specifier           | : Specifies the format of the op-code. The code lengths of the op-<br>code and operand vary with the op-code format. (Normally<br>omitted.) |

## Specifiers

| Size specifier | Content                            |
|----------------|------------------------------------|
| .В             | Specifies byte size. (8 bits)      |
| .W             | Specifies word size. (16 bits)     |
| .L             | Specifies long word size (32 bits) |

| Branch distance specifier | Content                                            |
|---------------------------|----------------------------------------------------|
| .S                        | Branch distance: +2 to +9 (3-bit forward relative) |
| .В                        | Branch distance: -128 to +127 (8-bit relative)     |
| .W                        | Branch distance: -32768 to +32767 (16-bit relative |
| .A                        | Branch distance: 0 to FFFFFFH (24-bit absolute)    |

| Instruction format specifier(Note) | Content        | Selection priority |
|------------------------------------|----------------|--------------------|
| .Z                                 | Zero format    | High               |
| .S                                 | Short format   | l f                |
| .Q                                 | Quick format   | ↓ ↓                |
| .G                                 | Generic format | Low                |

Note: Some instructions do not have the instruction format specifier.

## Figure 2.6.2 Specifiers



# Instruction format

#### 1.Generic format(:G)

The op-code includes information on the operation to be performed, as well as src and dest addressing information.

#### Table 2.6.1 Generic format

| Op-code      | Src code     | Dest code    |
|--------------|--------------|--------------|
| 2 to 3 bytes | 0 to 4 bytes | 0 to 3 bytes |

## 2.Quick format(:Q)

The op-code includes information on the operation to be performed and the immediate data, as well as dest addressing information. However, the immediate data included in the op-code is a value that can be expressed by -7 to +8 or -8 to +7 (varying with the instruction).

#### Table 2.6.2 Quick format

| Op-code | Dest code    |
|---------|--------------|
| 2 bytes | 0 to 3 bytes |

#### 3.Short format(:S)

The op-code includes information on the operation to be performed, as well as src and dest addressing information. However, the usable addressing modes are limited. The S format can be used in part of addressing modes.

#### Table 2.6.3 Short format

| Op-code | Src code     | Dest code    |  |  |  |  |
|---------|--------------|--------------|--|--|--|--|
| 1 byte  | 0 to 2 bytes | 0 to 2 bytes |  |  |  |  |

## 4.Zero format(:Z)

The op-code includes information on the operation to be performed and the immediate data, as well as dest addressing information. However, the immediate data is fixed to 0. The Z format can be used in part of addressing modes.

## Table 2.6.4 Zero format

| Op-code | Dest code    |
|---------|--------------|
| 1 byte  | 0 to 2 bytes |



## 2.6.2 Instruction List

In this and following pages, instructions are summarized by function in list form, showing the content of each mnemonic, addressing, and flag changes.

## Transfer

| Mnerr                            | nonic                                        | Explanation                                                                                                                                                                                                                                                              |
|----------------------------------|----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MOV.size <sup>(Note)</sup>       | src,dest                                     | Transfers src to dest or sets immediate in dest.                                                                                                                                                                                                                         |
| MOVA src,dest                    |                                              | Transfers address in src to dest.                                                                                                                                                                                                                                        |
| MOVHH<br>MOVHL<br>MOVLH<br>MOVLL | src,dest<br>src,dest<br>src,dest<br>src,dest | Transfers 4 high-order bits in src to 4 high-order bits in dest.<br>Transfers 4 high-order bits in src to 4 low-order bits in dest.<br>Transfers 4 low-order bits in src to 4 high-order bits in dest.<br>Transfers 4 low-order bits in src to 4 low-order bits in dest. |
| MOVX                             | src,dest                                     | Sign-extends 8-bit immediate value to 32 bits before transferring to dest.                                                                                                                                                                                               |
| POP.size                         | dest                                         | Restores value from stack area.                                                                                                                                                                                                                                          |
| POPC                             | dest                                         | Restores value from stack area to dedicated register indicated by dest.                                                                                                                                                                                                  |
| POPM                             | dest                                         | Restores multiple registers values collectively from stack area.                                                                                                                                                                                                         |
| PUSH.size                        | src                                          | Saves register / memory / immediate to stack area.                                                                                                                                                                                                                       |
| PUSHA                            | src                                          | Saves address in src to stack area.                                                                                                                                                                                                                                      |
| PUSHC                            | src                                          | Saves dedicated src register to stack area.                                                                                                                                                                                                                              |
| PUSHM                            | src                                          | Saves multiple registers tp stack area.                                                                                                                                                                                                                                  |
| SIN.size                         |                                              | Transfers string in address incrementing direction using A0 as fixed source address of transfer, A1 as destination address of transfer, and R3 as transfer count.                                                                                                        |
| SMOVB.size                       |                                              | Transfers string in address decrementing direction using A0 as source address of transfer, A1 as destination address of transfer, and R3 as transfer count.                                                                                                              |
| SMOVF.size                       |                                              | Transfers string in address incrementing direction using A0 as source address of transfer, A1 as destination address of transfer, and R3 as transfer count.                                                                                                              |
| SMOVU.size                       |                                              | Transfers string in address incrementing direction using A0 as source address of transfer, A1 as destination address of transfer, and R3 as transfer count until 0 is detected.                                                                                          |

|                   | Addressing |          |                   |                              |                              |             |             |                           |                            |                             | Fla | ag c | har | ige |    |    |    |    |
|-------------------|------------|----------|-------------------|------------------------------|------------------------------|-------------|-------------|---------------------------|----------------------------|-----------------------------|-----|------|-----|-----|----|----|----|----|
|                   |            |          | Ger               | neral i                      | nstruc                       | tion        |             |                           | Spe<br>instru              | ecial<br>uction             |     |      |     |     |    |    |    |    |
| Operand           | Immediate  | Absolute | Register direct   | Address register<br>indirect | Address register<br>relative | SB relative | FB relative | Stack pointer<br>relative | Control register<br>direct | Program counter<br>relative | U   |      | 0   | В   | s  | Z  | D  | с  |
| SrC*f             | 0          | 0        | 0                 | 0                            | 0                            | 0           | 0           | 0                         |                            |                             |     |      |     |     |    |    |    |    |
| dest*f            |            | 0        | 0                 | 0                            | 0                            | 0           | 0           | 0                         |                            |                             | 1 - | -    | -   | -   | 0  | 0  | -  | -  |
| src               |            | 0        |                   |                              | 0                            | 0           | 0           |                           |                            |                             |     | -    | _   | -   | -  | _  | -  | -  |
| dest              |            |          | 0                 |                              |                              |             |             |                           |                            |                             |     | Ľ    |     | _   |    |    | _  | _  |
| src               |            |          | ROL <sup>*a</sup> |                              |                              |             |             |                           |                            |                             |     |      |     |     |    |    |    |    |
| dest              |            | 0        | O.P               | 0                            | 0                            | 0           | 0           |                           |                            |                             |     |      |     | -   | -  | _  | -  | -  |
| src               |            | 0        | O.P               | 0                            | 0                            | 0           | 0           |                           |                            |                             | 1-  | -    | -   | -   | -  | -  | -  | -  |
| dest              |            |          | ROL <sup>*a</sup> |                              |                              |             |             |                           |                            |                             | 1   |      |     |     |    |    |    |    |
| src               | O⁺c        |          |                   |                              |                              |             |             |                           |                            |                             |     | _    | -   | -   | 0  | 0  |    | -  |
| dest*f            |            | 0        | 0                 | 0                            | 0                            | 0           | 0           |                           |                            |                             |     | -    | -   | -   | 0  | 0  | -  | -  |
| dest*f            |            | 0        | 0                 | 0                            | 0                            | 0           | 0           |                           |                            |                             | -   | -    | -   | -   | -  | -  | -  | -  |
| dest              |            |          |                   |                              |                              |             |             |                           | O <sup>*d</sup>            |                             | *е  | *e   | *е  | *e  | *е | *e | *е | *е |
| dest              |            |          |                   |                              |                              |             |             |                           | 0                          |                             | -   | -    | -   | -   | -  | -  | -  | -  |
| src <sup>*f</sup> | 0          | 0        | 0                 | 0                            | 0                            | 0           | 0           |                           |                            |                             | -   | -    | -   | -   | -  | -  | -  | -  |
| src               |            | 0        |                   |                              | 0                            | 0           | 0           |                           |                            |                             | -   | -    | -   | -   | -  | -  | -  | -  |
| src               |            |          |                   |                              |                              |             |             |                           | O <sup>*d</sup>            |                             | -   | -    | -   | -   | -  | -  | -  | -  |
| src               |            |          | 0                 |                              |                              |             |             |                           | 0                          |                             | -   | -    | -   | -   | -  | -  | -  | -  |
|                   |            |          |                   |                              |                              |             |             |                           |                            |                             | -   | -    | -   | -   | -  | -  | -  | -  |
|                   |            |          |                   |                              |                              |             |             |                           |                            |                             | -   | -    | 1   | -   | -  | I  | 1  | -  |
|                   |            |          |                   |                              |                              |             |             |                           |                            |                             | -   | -    | -   | -   | -  | -  | -  | -  |
|                   |            |          |                   |                              |                              |             |             |                           |                            |                             | -   | -    | -   | -   | -  | -  | -  | -  |

\*a R0L register is selected for src or dest..

\*b Can be selected from R0L, R0H, R1L, or R1H.

\*c The immediate value is 8 bits in size, whose possible value is -128 < #IMM8 < +127.

\*d When SP is specified, the stack pointer indicated by the U flag is the target.

\*e It is only when FLG is specified that dest changes.

\*f Indirect addressing [src] and [dest] can be used in any register other than R0L/R0/R2R0, R0H/ R2/-, R1H/R3/-, SP/SP/SP, dsp:8[SP], and #IMM.

| Mnemonic                    | Explanation                                                                                                                                                             |
|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SOUT.size <sup>(Note)</sup> | Transfers string in address incrementing direction using A0<br>as source address of transfer, A1 as fixed destination<br>address of transfer, and R3 as transfer count. |
| SSTR.size                   | Transfers string in address incrementing direction using R0L/R0 as store data, A1 as destination address of transfer, and R3 as transfer count.                         |
| STNZ.size src,dest          | Transfers src to dest when Z flag = 0.                                                                                                                                  |
| STZ.size src,dest           | Transfers src to dest when Z flag = 1.                                                                                                                                  |
| STZX.size src1,src2,dest    | Transfers src1 to dest when Z flag = 1 or src2 to dest when Z flag = 0.                                                                                                 |
| XCHG.size src,dest          | Exchanges contents of src and dest with each other.                                                                                                                     |

Note:Write .W or .B for .size.

|                    |                 |          |                 | Ad                           | dressi                       | ng          |             |                           |                            |                             |   |   | Fla | ig c | han | ge |   |   |
|--------------------|-----------------|----------|-----------------|------------------------------|------------------------------|-------------|-------------|---------------------------|----------------------------|-----------------------------|---|---|-----|------|-----|----|---|---|
|                    |                 | -        | Ger             | neral i                      | nstruc                       | tion        | _           |                           | Spe<br>instru              | ecial<br>Iction             |   |   |     |      |     |    |   |   |
| Operand            | Immediate       | Absolute | Register direct | Address register<br>indirect | Address register<br>relative | SB relative | FB relative | Stack pointer<br>relative | Control register<br>direct | Program counter<br>relative | U | I | 0   | в    | s   | z  | D | с |
|                    |                 |          |                 |                              |                              |             |             |                           |                            |                             | - | - | -   | -    | -   | -  | - | - |
|                    |                 |          |                 |                              |                              |             |             |                           |                            |                             | - | - | -   | -    | -   | -  | - | - |
| src                | O <sup>*g</sup> |          |                 |                              |                              |             |             |                           |                            |                             |   |   |     |      |     |    |   |   |
| dest <sup>*h</sup> |                 | 0        | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             |   | - | -   | -    | -   | -  | - | - |
| src                | O⁺g             |          |                 |                              |                              |             |             |                           |                            |                             |   |   | -   | -    | -   |    |   | _ |
| dest*h             |                 | 0        | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             | - | _ | -   | _    | _   |    | _ | - |
| src                | 0               |          |                 |                              |                              |             |             |                           |                            |                             |   |   | _   |      | -   | _  |   | - |
| dest*h             |                 | 0        | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             |   |   |     |      |     |    |   | _ |
| src                |                 |          | 0               |                              |                              |             |             |                           |                            |                             | _ | _ | -   | -    | -   | _  | - | - |
| dest*h             |                 | 0        | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             |   |   |     |      |     |    |   |   |

\*g The immediate value is selected for 8/16 bits in size.

\*h Indirect addressing [dest] can be used in any register other than R0L/R0/R2R0, R0H/ R2/-, R1H/R3/-, SP/SP/SP, dsp:8[SP], and #IMM.



## **Bit Manipulation**

| Mnemor           | nic   | Explanation                                                                                                |                              |
|------------------|-------|------------------------------------------------------------------------------------------------------------|------------------------------|
| BAND             | src   | C flag ← src & C flag                                                                                      | ; ANDs bits.                 |
| BCLR             | dest  | dest ←0                                                                                                    | ; Clears bits.               |
| BITINDEX.size    | e src | Operand specified by src becomes the src<br>next bit instruction.                                          | c or dest index value of the |
| BMGEU/C          | dest  | If C=1, dest $\leftarrow$ 1; otherwise, dest $\leftarrow$ 0; Co                                            | onditionally transfers bit.  |
| BM <i>LTU/NC</i> | dest  | If C=0, dest $\leftarrow$ 1; otherwise, dest $\leftarrow$ 0                                                |                              |
| BM <i>E</i> Q/Z  | dest  | If Z=1, dest $\leftarrow$ 1; otherwise, dest $\leftarrow$ 0                                                |                              |
| BM <i>NE/NZ</i>  | dest  | If Z=0, dest $\leftarrow$ 1; otherwise, dest $\leftarrow$ 0                                                |                              |
| BMGTU            | dest  | If C $\Lambda$ Z=1, dest $\leftarrow$ 1; otherwise, dest $\leftarrow$                                      | 0                            |
| BMLEU            | dest  | If C $\Lambda$ Z=0, dest $\leftarrow$ 1; otherwise, dest $\leftarrow$                                      | 0                            |
| BM <i>PZ</i>     | dest  | If S=0, dest $\leftarrow$ 1; otherwise, dest $\leftarrow$ 0                                                |                              |
| BMN              | dest  | If S=1, dest $\leftarrow$ 1; otherwise, dest $\leftarrow$ 0                                                |                              |
| BMGE             | dest  | If S $\forall$ O=0, dest $\leftarrow$ 1; otherwise, dest $\leftarrow$                                      | 0                            |
| BMLE             | dest  | If (S $\forall$ O) V Z=1, dest $\leftarrow$ 1; otherwise, de                                               | $est \leftarrow 0$           |
| BMGT             | dest  | If (S $\forall$ O) V Z=0, dest $\leftarrow$ 1; otherwise, de                                               | $est \leftarrow 0$           |
| BMLT             | dest  | If S $\forall$ O=1, dest $\leftarrow$ 1; otherwise, dest $\leftarrow$                                      | 0                            |
| BMO              | dest  | If O=1, dest $\leftarrow$ 1; otherwise, dest $\leftarrow$ 0                                                |                              |
| BMNO             | dest  | If O=0, dest $\leftarrow$ 1; otherwise, dest $\leftarrow$ 0                                                |                              |
| BNAND            | src   | $C  flag \gets src \Lambda C  flag$                                                                        | ; ANDs inverted bits.        |
| BNOR             | src   | $C  flag \gets src V C  flag$                                                                              | ; ORs inverted bits.         |
| BNOT             | dest  | Inverts dest and stores in dest.                                                                           | ; Inverts bit.               |
| BNTST            | src   | $Z  flag \gets src, C  flag \gets src$                                                                     | ; Tests inverted bit.        |
| BNXOR            | src   | $C  flag \gets src \ \forall \ C \ flag \qquad ; Exclusiv$                                                 | e ORs inverted bits.         |
| BOR              | src   | $C  flag \gets src V C  flag$                                                                              | ;ORs bits.                   |
| BSET             | dest  | dest $\leftarrow$ 1                                                                                        | ;Sets bit.                   |
| BTST             | src   | Z flag $\leftarrow$ src, C flag $\leftarrow$ src                                                           | ;Tests bit.                  |
| BTSTC            | dest  | $Z \text{ flag} \leftarrow \text{dest}, C \text{ flag} \leftarrow \text{dest}, \text{dest} \leftarrow 0$ ; | Tests and clears bit.        |
| BTSTS            | dest  | - 3                                                                                                        | Tests and sets bit.          |
| BXOR             | src   | $C  flag \gets src \forall C  flag$                                                                        | ; Eclusive ORs bits.         |

| - 1     |          |                 | Addre                        |                              |             |             |            |   |   | F | lag c | hang | je |   |     |
|---------|----------|-----------------|------------------------------|------------------------------|-------------|-------------|------------|---|---|---|-------|------|----|---|-----|
|         |          |                 | Bit i                        | nstruc                       | tion        |             |            |   |   |   |       |      |    |   |     |
| Operand | Absolute | Register direct | Address register<br>indirect | Address register<br>relative | SB relative | FB relative | FLG direct | U | 1 | 0 | В     | S    | z  | D | с   |
| src     | 0        | 0               | 0                            | 0                            | 0           | 0           |            | - | - | - | -     | -    | -  | - | 0   |
| dest    | 0        | 0               | 0                            | 0                            | 0           | 0           |            | - | - | - | -     | -    | -  | - | -   |
| src     | 0        | 0               | 0                            | 0                            | 0           | 0           |            | - | - | - | -     | -    | -  | - | -   |
| dest    | 0        | 0               | 0                            | 0                            | 0           | 0           | 0          | - | - | - | -     | -    | -  | - | 0°i |
| src     | 0        | 0               | 0                            | 0                            | 0           | 0           |            | - | - | - | -     | -    | -  | - | 0   |
| dest    | 0        | 0               | 0                            | 0                            | 0           | 0           |            | - | - | - | -     | -    | -  | - | -   |
| src     | 0        | 0               | 0                            | 0                            | 0           | 0           |            | - | - | - | -     | -    | 0  | - | 0   |
| src     | 0        | 0               | 0                            | 0                            | 0           | 0           |            | - | - | - | -     | -    | -  | - | 0   |
| src     | 0        | 0               | 0                            | 0                            | 0           | 0           |            | - | - | - | -     | -    | -  | - | 0   |
| dest    | 0        | 0               | 0                            | 0                            | 0           | 0           |            | - | - | - | -     | -    | -  | - | -   |
| src     | 0        | 0               | 0                            | 0                            | 0           | 0           |            | - | - | - | -     | -    | 0  | - | 0   |
| dest    | 0        | 0               | 0                            | 0                            | 0           | 0           |            | - | - | - | -     | -    | 0  | - | 0   |
| dest    | 0        | 0               | 0                            | 0                            | 0           | 0           |            | - | - | - | -     | -    | 0  | - | 0   |
| src     | 0        | 0               | 0                            | 0                            | 0           | 0           |            | - | - | - | -     | -    | -  | - | 0   |

RENESAS

\*f Flag changes when C flag is specified for dest.



## Arithmetic

|                            | nemonic        |                                                    | Explanation                                                        |
|----------------------------|----------------|----------------------------------------------------|--------------------------------------------------------------------|
| ABS.size <sup>(Note)</sup> | dest           | dest ←  dest                                       | ;Absolute value of dest.                                           |
| ADC.size                   | src,dest       | $dest \gets src + dest + C flag$                   | ;Adds hexadecimal with carry.                                      |
| ADCF.size                  | dest           | $dest \gets dest + C flag$                         | ;Adds carry flag.                                                  |
| ADD.size                   | src,dest       | dest $\leftarrow$ src + dest                       | ;Adds hexadecimal without carry.                                   |
| ADDX                       | src,dest       | dest ← dest - 32-bit sign exter<br>;Hexadecimal a  | nsion (src)<br>addition without sign extension carry.              |
| AND.size                   | src,dest       | dest $\leftarrow$ src / dest                       | ;Logical AND                                                       |
| CLIP.size                  | src1,src2,dest | if src1 > dest then dest $\leftarrow$ src1         | 1, if src2 > dest then dest $\leftarrow$ src2<br>;Clip instruction |
| CMP.size                   | src,dest       | dest - src ;Comp                                   | arison, with result determined by flag.                            |
| CMPX                       | src,dest       | dest - 32-bit sign extension (sr<br>;Comparison, v | c)<br>with result determined by flag.                              |
| DADC.size                  | src,dest       | $dest \gets src + dest + C flag$                   | ;Decimal addition with carry.                                      |
| DADD.size                  | src,dest       | $dest \gets src + dest$                            | ;Decimal addition without carry.                                   |
| DEC.size                   | dest           | dest ← dest - 1                                    | ;Decrement                                                         |
| DIV.size                   | SIC            | R0 (Quotient), R2 (Remainder) $\leftarrow$ R2      | R0 ÷ src ;Division with sign included.                             |
| DIVU.size                  | SIC            | R0 (Quotient), R2 (Remainder) $\leftarrow$ R2      | R0 ÷ src ;Division without sign included.                          |
| DIVX.size                  | SIC            | R0 (Quotient), R2 (Remainder) $\leftarrow$ R2      | R0 ÷ src ;Division with sign included.                             |
| DSBB.size                  | src,dest       | dest ← dest - src - C flag                         | ; Decimal subtraction with borrow.                                 |

|               |           | Addressing<br>General instruction Special |                 |                              |                              |             |             |                           |                            |                             |   |   | Flag change |   |   |   |   |   |  |  |  |  |
|---------------|-----------|-------------------------------------------|-----------------|------------------------------|------------------------------|-------------|-------------|---------------------------|----------------------------|-----------------------------|---|---|-------------|---|---|---|---|---|--|--|--|--|
|               |           |                                           | Ger             | neral i                      | nstruc                       | tion        |             |                           |                            | ecial<br>uction             |   |   |             |   |   |   |   |   |  |  |  |  |
|               |           |                                           |                 |                              |                              |             |             |                           | 1115010                    |                             |   |   |             |   |   |   |   |   |  |  |  |  |
| Operand       | Immediate | Absolute                                  | Register direct | Address register<br>indirect | Address register<br>relative | SB relative | FB relative | Stack pointer<br>relative | Control register<br>direct | Program counter<br>relative | U | 1 | 0           | В | S | Z | D | с |  |  |  |  |
| dest*j        |           | 0                                         | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             | - | - | 0           | - | 0 | 0 | - | 0 |  |  |  |  |
| src           | 0         | 0                                         | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             | _ | - | 0           | - | 0 | 0 | 1 | 0 |  |  |  |  |
| dest          |           | 0                                         | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             |   |   |             |   |   | _ |   |   |  |  |  |  |
| dest*j        |           | 0                                         | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             | - | - | 0           | - | 0 | 0 | - | 0 |  |  |  |  |
| src*j         | 0         | 0                                         | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             | - | - | 0           | - | ο | 0 | - | 0 |  |  |  |  |
| dest*j        |           | 0                                         | 0               | 0                            | 0                            | 0           | 0           |                           | SP                         |                             |   |   | Ľ           |   | - | _ |   | Ŭ |  |  |  |  |
| src*j         | 0         | 0                                         | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             | - | - | 0           | - | ο | ο | - | 0 |  |  |  |  |
| dest*j        |           | 0                                         | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             |   |   |             |   | _ | - |   |   |  |  |  |  |
| src*j         | 0         | 0                                         | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             | - | - | -           | - | 0 | 0 | - | - |  |  |  |  |
| dest*j        |           | 0                                         | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             |   |   |             |   |   |   |   |   |  |  |  |  |
| src           | 0         |                                           |                 |                              | _                            |             | _           |                           |                            |                             | - | - | -           | - | - | - | - | - |  |  |  |  |
| dest          |           | 0                                         | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             |   |   |             |   |   |   |   |   |  |  |  |  |
| src*j         | 0         | 0                                         | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             | - | - | 0           | - | 0 | 0 | - | 0 |  |  |  |  |
| dest*j        |           | О                                         | 0               | 0                            | 0                            | О           | 0           |                           |                            |                             |   |   |             |   |   |   |   |   |  |  |  |  |
| src<br>dest⁺i | 0         | 0                                         | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             | - | - | 0           | - | 0 | 0 | - | 0 |  |  |  |  |
| src           | 0         | 0                                         | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             |   |   |             |   |   |   |   |   |  |  |  |  |
| dest          |           | 0                                         | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             | - | - | -           | - | 0 | 0 | - | 0 |  |  |  |  |
| src           | 0         | 0                                         | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             |   |   |             |   |   |   |   |   |  |  |  |  |
| dest          | -         | 0                                         | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             | - | - | -           | - | 0 | 0 | - | 0 |  |  |  |  |
| dest*j        |           | 0                                         | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             | - | - | -           | - | 0 | 0 | - | - |  |  |  |  |
| src*j         | 0         | 0                                         | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             | - | - | 0           | - | - | - | - | - |  |  |  |  |
| src*j         | 0         | 0                                         | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             | - | - | 0           | - | - | - | - | - |  |  |  |  |
| src*j         | 0         | 0                                         | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             | - | - | 0           | - | - | - | - | - |  |  |  |  |
| src           | 0         | 0                                         | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             |   |   |             |   |   |   |   |   |  |  |  |  |
| dest          |           | 0                                         | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             | - | - | -           | - | 0 | 0 | - | 0 |  |  |  |  |

\*j Indirect addressing [dest] can be used in any register other than R0L/R0/R2R0, R0H/ R2/-, R1H/R3/-, SP/SP/SP, dsp:8[SP], and #IMM.



| Mnemo                       | onic     | Explanation                                                                                                                               |
|-----------------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------|
| DSUB.size <sup>(Note)</sup> | src,dest | dest $\leftarrow$ dest - src ; Decimal subtraction without borrow.                                                                        |
| INC.size                    | dest     | dest $\leftarrow$ dest + 1 ;Increment.                                                                                                    |
| MAX.size                    | src,dest | if (src > dest) then dest $\leftarrow$ src ;Selects maximum value.                                                                        |
| MIN.size                    | src,dest | if (src < dest) then dest $\leftarrow$ src ;Selects minimum value.                                                                        |
| MUL.size                    | src,dest | dest $\leftarrow$ dest X src ;Multiplication with sign included.                                                                          |
| MULEX                       | src      | $\begin{array}{l} \text{R1R2R0} \leftarrow \text{R2R0} \text{ X src} \\ \text{;Extended multiplication with sign included }. \end{array}$ |
| MULU.size                   | src,dest | $dest \gets dest \; X \; src \qquad ; Multiplication \; without \; sign \; included.$                                                     |
| NEG.size                    | dest     | dest $\leftarrow$ 0 - dest ;Two's complement.                                                                                             |
| NOT.size                    | dest     | dest $\leftarrow$ dest ;Invert all bits.                                                                                                  |
| OR.size                     | src,dest | $dest \gets dest \; V \; src \qquad \qquad ; Logical \; OR.$                                                                              |
| RMPA.size                   |          | Calculates sum-of-products using A0 as multiplicand address,<br>A1 as multiplier address, and R3 as count.                                |
| ROLC.size                   | dest     | Rotates dest including C flag left by 1 bit ;Rotate left with carry.                                                                      |
| RORC.size                   | dest     | Rotate dest including C flag right by 1 bit ;Rotate right with carry.                                                                     |
| ROT.size                    | src,dest | Rotate dest as many bits as indicated by signed src ;Rotate.                                                                              |
| SBB.size                    | src,dest | dest $\leftarrow$ dest - src - C ;Subtraction with borrow.                                                                                |

Note:Write .W or .B for .size.

| RENESAS |
|---------|
|---------|

|                     |           |          |                 | Ad                           | dressi                       | ng          |             |                           |                            |                             |   |   | Fla | ag c | han | ge |   |   |
|---------------------|-----------|----------|-----------------|------------------------------|------------------------------|-------------|-------------|---------------------------|----------------------------|-----------------------------|---|---|-----|------|-----|----|---|---|
|                     |           |          | Gei             | neral i                      | nstruc                       | tion        |             |                           | Spe<br>instru              | ecial                       |   |   |     |      |     |    |   |   |
|                     |           |          |                 |                              |                              |             |             |                           | 11300                      |                             |   |   |     |      |     |    |   |   |
| Operand             | Immediate | Absolute | Register direct | Address register<br>indirect | Address register<br>relative | SB relative | FB relative | Stack pointer<br>relative | Control register<br>direct | Program counter<br>relative | U | Ι | 0   | В    | S   | Z  | D | С |
| src                 | 0         | 0        | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             | _ | - | -   | -    | 0   | 0  | - | 0 |
| dest                |           | 0        | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             |   |   |     |      |     | _  |   | _ |
| dest*k              |           | 0        | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             | - | - | -   | -    | 0   | 0  | - | 0 |
| src                 | 0         | 0        | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             |   | - | -   | -    | -   | -  | - | - |
| dest                |           | 0        | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             |   |   |     |      |     |    |   |   |
| src                 | 0         | 0        | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             |   | - | -   | -    | -   | -  | - | - |
| dest                |           | 0        | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             |   |   |     |      |     |    |   |   |
| SrC*k               | 0         | 0        | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             |   | - | -   | -    | -   | -  | - | - |
| dest*k              |           | 0        | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             |   |   |     |      |     |    |   |   |
| src⁺ <sup>k</sup>   |           | 0        | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             | - | - | -   | -    | -   | -  | - | - |
| SrC*k               | 0         | 0        | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             | _ | - | _   | -    | -   | _  | _ | - |
| dest*k              |           | 0        | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             |   |   |     |      |     |    |   |   |
| dest*k              |           | 0        | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             | - | - | 0   | -    | 0   | 0  | - | 0 |
| dest*k              |           | 0        | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             | I | - | -   | -    | 0   | 0  | - | 0 |
| src*k               | 0         | 0        | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             |   | - | _   | -    | 0   | 0  | _ | - |
| dest*k              |           | 0        | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             |   |   |     |      | Ŭ   | Ŭ  |   |   |
|                     |           |          |                 |                              |                              |             |             |                           |                            |                             | - | - | 0   | -    | -   | -  | - | - |
| dest*k              |           | 0        | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             | - | - | -   | -    | 0   | 0  | - | 0 |
| dest <sup>∗</sup> k |           | 0        | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             | - | - | -   | -    | 0   | 0  | - | 0 |
| src*k               | O*I       | O*m      |                 |                              |                              |             |             |                           |                            |                             |   |   |     |      |     |    |   |   |
| dest*k              |           | 0        | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             | - | - | -   | -    | 0   | 0  | - | 0 |
| src                 | 0         | 0        | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             |   |   | 0   |      | 0   | 0  |   | 0 |
| dest                |           | 0        | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             |   |   |     |      |     |    | - |   |
| -                   |           |          | _               |                              |                              | _           |             |                           |                            |                             |   |   |     |      |     |    | _ |   |

\*k Indirect addressing [dest] can be used in any register other than R0L/R0/R2R0, R0H/ R2/-, R1H/R3/-, SP/SP/SP, dsp:8[SP], and #IMM.

\*I The range of possible values is -8 < #IMM4 < +8.

\*m Choose R1H.

| Mnen                       | nonic    | Explanation                                                                                                                                                                                                     |
|----------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SCGEU/C                    | dest     | If C=1, dest $\leftarrow$ 1;otherwise, dest $\leftarrow$ 0 ;Set conditions.                                                                                                                                     |
| SCLTU/NC                   | dest     | If C=0, dest $\leftarrow$ 1;otherwise, dest $\leftarrow$ 0                                                                                                                                                      |
| SCEQ/Z                     | dest     | If Z=1, dest $\leftarrow$ 1;otherwise, dest $\leftarrow$ 0                                                                                                                                                      |
| SC <i>NE/NZ</i>            | dest     | If Z=0, dest $\leftarrow$ 1;otherwise, dest $\leftarrow$ 0                                                                                                                                                      |
| SCGTU                      | dest     | If C $\Lambda$ Z=1, dest $\leftarrow$ 1;otherwise, dest $\leftarrow$ 0                                                                                                                                          |
| SCLEU                      | dest     | If C $\Lambda$ Z=0, dest $\leftarrow$ 1;otherwise, dest $\leftarrow$ 0                                                                                                                                          |
| SCPZ                       | dest     | If S=0, dest $\leftarrow$ 1;otherwise, dest $\leftarrow$ 0                                                                                                                                                      |
| SCN                        | dest     | If S=1, dest $\leftarrow$ 1;otherwise, dest $\leftarrow$ 0                                                                                                                                                      |
| SCGE                       | dest     | If S $\forall$ O=0, dest $\leftarrow$ 1;otherwise, dest $\leftarrow$ 0                                                                                                                                          |
| SCLE                       | dest     | If (S $\forall$ O) V Z=1, dest $\leftarrow$ 1;otherwise, dest $\leftarrow$ 0                                                                                                                                    |
| SCGT                       | dest     | If (S $\forall$ O) V Z=0, dest $\leftarrow$ 1;otherwise, dest $\leftarrow$ 0                                                                                                                                    |
| SCLT                       | dest     | If S $\forall$ O=1, dest $\leftarrow$ 1;otherwise, dest $\leftarrow$ 0                                                                                                                                          |
| SCO                        | dest     | If O=1, dest $\leftarrow$ 1;otherwise, dest $\leftarrow$ 0                                                                                                                                                      |
| SCNO                       | dest     | I O=0, dest $\leftarrow$ 1;otherwise, dest $\leftarrow$ 0                                                                                                                                                       |
| SCMPU.size                 |          | Compares strings successively in address incrementing direction using A0 as source address to compare and A1 as destination address to compare until comparison results in unmatch or source address becomes 0. |
| SHA.size                   | src,dest | Arithmetically shifts dest as many bits as indicated by src. Bit overflowing from LSB (MSB) is transferred to C flag.                                                                                           |
| SHL.size                   | src,dest | Logically shifts dest as many bits as indicated by src. Bit<br>overflowing from LSB (MSB) is transferred to C flag.                                                                                             |
| SUB.size                   | src,dest | dest $\leftarrow$ dest - src ;Sbtraction without borrow.                                                                                                                                                        |
| SUBX                       | src,dest | dest ← dest - 32-bit sign extension (src)<br>;Extended subtraction without borrow.                                                                                                                              |
| TST.size                   | src,dest | dest A src ;Test                                                                                                                                                                                                |
| XOR.size <sup>(Note)</sup> | src,dest | dest $\leftarrow$ dest $\forall$ src ;Exclusive logical OR.                                                                                                                                                     |
| L                          |          | +                                                                                                                                                                                                               |

| RENESAS |
|---------|
|---------|

|                 |           | Addressing Special |                 |                              |                              |             |             |                           |                            |                             |   |   | Flag change |   |   |   |   |   |  |  |  |  |
|-----------------|-----------|--------------------|-----------------|------------------------------|------------------------------|-------------|-------------|---------------------------|----------------------------|-----------------------------|---|---|-------------|---|---|---|---|---|--|--|--|--|
|                 |           |                    | Ger             | neral li                     | nstruc                       | tion        |             |                           | Spe<br>instru              | ecial<br>Iction             |   |   |             |   |   |   |   |   |  |  |  |  |
| Operand         | Immediate | Absolute           | Register direct | Address register<br>indirect | Address register<br>relative | SB relative | FB relative | Stack pointer<br>relative | Control register<br>direct | Program counter<br>relative | U | I | 0           | В | S | Z | D | С |  |  |  |  |
| dest*^          |           | 0                  | 0               | 0                            | ο                            | 0           | 0           |                           |                            |                             | - | - | -           | - | - |   |   | - |  |  |  |  |
| src             |           |                    |                 |                              |                              |             |             |                           |                            |                             | - | - | 0           | - | 0 | 0 | - | 0 |  |  |  |  |
| src*n           | O⁺⁰       |                    | R1H             |                              |                              |             |             |                           |                            |                             |   | - | 0           | - | 0 | 0 | - | 0 |  |  |  |  |
| dest*n          |           | 0                  | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             |   |   | Ĺ           |   | Ĺ |   |   |   |  |  |  |  |
| STC*n           | O⁺⁰       |                    | R1H             |                              |                              |             |             |                           |                            |                             |   | - | 0           | - | 0 | 0 | - | 0 |  |  |  |  |
| dest*n          |           | 0                  | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             |   |   | <u> </u>    |   |   |   |   |   |  |  |  |  |
| src*n<br>dest*n | 0         | 0 0                | 0               | 0                            | 0 0                          | 0           | 0           |                           |                            |                             |   | - | 0           | - | 0 | 0 | - | 0 |  |  |  |  |
| src*n           | 0         | 0                  | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             |   |   | -           |   |   |   |   |   |  |  |  |  |
| dest*n          |           | 0                  | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             |   | - | 0           | - | 0 | 0 | - | 0 |  |  |  |  |
| src             | 0         | 0                  | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             |   |   |             |   |   |   |   |   |  |  |  |  |
| dest            |           | 0                  | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             |   | - | -           | - | 0 | 0 | - | - |  |  |  |  |
| src*n           | 0         | 0                  | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             |   |   |             |   |   |   |   |   |  |  |  |  |
| dest*n          |           | 0                  | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             | _ | - | -           | - | 0 | 0 | - | - |  |  |  |  |

\*n Indirect addressing [src] and [dest] can be used in any register other than R0L/R0/R2R0, R0H/ R2/-, R1H/R3/-, SP/SP/SP, dsp:8[SP], and #IMM.

\*o When (.size) is (.B) or (.W), the range of possible values is -8 < #IMM4 < +8 (( 0); when (.L), the range of possible values is -16 < #IMM8 < +16 (( 0).

# RENESAS

#### JUMP

| Mne                        | monic                         | Explanation                                                                                         |
|----------------------------|-------------------------------|-----------------------------------------------------------------------------------------------------|
| ADJNZ.size <sup>(Not</sup> | <sup>te)</sup> src,dest,label | dest dest + src<br>If result of dest + src is not 0, jump to label.<br>;Add and conditional branch. |
| JGEU/C                     | label                         | If C=1, jump to label ;otherwise, execute next instruction.<br>;Conditional branch.                 |
| JLTU/NC                    | label                         | If C=0, jump to label ;otherwise, execute next instruction.                                         |
| JEQ/Z                      | label                         | If Z=1, jump to label ;otherwise, execute next instruction.                                         |
| JNE/NZ                     | label                         | If Z=0, jump to label ;otherwise, execute next instruction.                                         |
| JGTU                       | label                         | If C $\Lambda$ Z=1, jump to label ;otherwise, execute next instruction.                             |
| JLEU                       | label                         | If C $\Lambda$ Z=0, jump to label ;otherwise, execute next instruction.                             |
| JPZ                        | label                         | If S=0, jump to label ;otherwise, execute next instruction.                                         |
| JN                         | label                         | If S=1, jump to label ;otherwise, execute next instruction.                                         |
| JGE                        | label                         | If S $\forall$ O=0, jump to label ;otherwise, execute next instruction.                             |
| JLE                        | label                         | If (S $\forall$ O) V Z=1, jump to label ;otherwise, execute next instruction.                       |
| JGT                        | label                         | If (S $\forall$ O) V Z=0, jump to label ;otherwise, execute next instruction.                       |
| JLT                        | label                         | If S $\forall$ O=1, jump to label ;otherwise, execute next instruction.                             |
| JO                         | label                         | If O=1, jump to label ;otherwise, execute next instruction.                                         |
| JNO                        | label                         | If O=0, jump to label ;otherwise, execute next instruction.                                         |
| JMP                        | label                         | Jump to label. ;Unconditional branch.                                                               |
| JMPI                       | src                           | Jump to address indicated by src. ;Indirect branch.                                                 |
| JMPS                       | src                           | Branches using special page vector table.                                                           |
| JSR                        | label                         | Subroutine call.                                                                                    |
| JSRI                       | src                           | Indirect subroutine call.                                                                           |
| JSRS                       | src                           | Calls subroutine using special page vector table.                                                   |
| RTS                        |                               | Return from subroutine.                                                                             |
| SBJNZ.size                 | src,dest,label                | Branches to label if the result of dest ← dest - src is not 0<br>;Subtraction & conditional branch. |

|         |                             |          |                 | Ad                           | dress                        | ing         |             |                           |                            |                             |   |   | Fla | ag c | han      | ge |   |   |
|---------|-----------------------------|----------|-----------------|------------------------------|------------------------------|-------------|-------------|---------------------------|----------------------------|-----------------------------|---|---|-----|------|----------|----|---|---|
|         |                             |          | Ger             | neral i                      | nstruc                       | tion        |             |                           | Spe                        | ecial<br>uction             |   |   |     |      |          |    |   |   |
|         |                             |          |                 |                              |                              |             |             |                           | insu                       | <b>I</b>                    | • |   |     |      |          |    |   |   |
| Operand | Immediate                   | Absolute | Register direct | Address register<br>indirect | Address register<br>relative | SB relative | FB relative | Stack pointer<br>relative | Control register<br>direct | Program counter<br>relative | U | I | 0   | В    | S        | Z  | D | С |
| src     | O <sup>*</sup> <sup>p</sup> |          |                 | _                            |                              |             | -           |                           |                            |                             |   |   |     |      |          |    |   |   |
| dest    |                             | 0        | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             |   | - | -   | -    | -        | -  | - | - |
| label   |                             |          |                 |                              |                              |             |             |                           |                            | label <sup>*</sup>          |   |   |     |      |          |    |   |   |
| label   |                             | 0*s      |                 |                              |                              |             |             |                           |                            | label <sup>-r</sup>         | - | - | -   | -    | -        | -  | - | - |
|         |                             |          |                 |                              |                              |             |             |                           |                            | label '                     |   |   |     |      | <u> </u> |    |   |   |
| src     |                             | 0        | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             | - | - | -   | -    | -        | -  | - | - |
| src     | O <sup>*</sup> u            | 0        | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             | - | - | -   | -    | -        | -  | - | - |
| src     | 0.                          | 0        | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             | - | - | -   | -    | -        | -  | - | - |
| src     | O <sup>*u</sup>             | 0        | 0               | 0                            |                              | 0           | 0           |                           |                            |                             | - | - | -   |      | -        | -  | - |   |
| src     | 0.                          |          |                 |                              |                              |             |             |                           |                            |                             | - | - | -   | -    | -        | -  | - | - |
| src     | Ov                          |          |                 |                              |                              |             |             |                           |                            |                             | - | - | -   | -    | -        | -  | - | - |
| dest    | 0.                          | 0        | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             | _ | - | -   |      |          |    | - | - |
| label   |                             |          | 0               | 0                            |                              | 0           |             |                           |                            | label <sup>*q</sup>         |   |   |     |      |          |    |   |   |
| lang    |                             |          |                 |                              |                              |             |             | ļ                         |                            | laner                       |   |   |     | L    | I        |    |   |   |

\*p The range of immediate values is -8 < #IMM4 < +7.

- \*q The range of label is PC 126 < label < PC + 129. PC is the start address of the instruction.
- \*r The range of label is PC 127 < label < PC + 128. PC is the start address of the instruction.
- \*s This is a 24-bit absolute address.
- \*t The range of label is PC 32767 < label < PC + 32768. PC is the start address of the instruction.
- \*u #IMM8 is a special page address.
- \*v The range of immediate values is -7 < #IMM4 < +8.



# Sign extension

| Mnemonic                         | Explanation                                                 |
|----------------------------------|-------------------------------------------------------------|
| EXTS.size <sup>(Note)</sup> dest | dest ← Sign extension (dest) conforming to .size.           |
| EXTS.size src,dest               | dest $\leftarrow$ Sign extension (src) conforming to .size. |
| EXTZ src,dest                    | dest                                                        |

## Index

| Mnemonic                                                        |     | Explanation                                                  |
|-----------------------------------------------------------------|-----|--------------------------------------------------------------|
| INDEX <i>B</i> .size <sup>(Note)</sup><br>INDEX <i>BD</i> .size | SrC | Madifia and instruction addression is units of hutan         |
| INDEX BD.size                                                   | SrC | Modifies next instruction addressing in units of bytes.      |
|                                                                 | src |                                                              |
| INDEX W.size                                                    | src |                                                              |
| INDEX WD.size                                                   | src | Modifies next instruction addressing in units of words.      |
| INDEX WS.size                                                   | src |                                                              |
| INDEX <i>L</i> .size                                            | src |                                                              |
| INDEX <i>LD</i> .size                                           | src | Modifies next instruction addressing in units of long words. |
| INDEX <i>LS</i> .size                                           | src |                                                              |

Note:Write .W or .B for .size.

|         |           |                        |                 | Ad                           | dressi                       | ng          |             |                           |                            |                             |   |   | Fla | ag c | har | ige |   |   |
|---------|-----------|------------------------|-----------------|------------------------------|------------------------------|-------------|-------------|---------------------------|----------------------------|-----------------------------|---|---|-----|------|-----|-----|---|---|
|         |           | Special<br>instruction |                 |                              |                              |             |             |                           |                            |                             |   |   |     |      |     |     |   |   |
| Operand | Immediate | Absolute               | Register direct | Address register<br>indirect | Address register<br>relative | SB relative | FB relative | Stack pointer<br>relative | Control register<br>direct | Program counter<br>relative | υ | - | 0   | В    | S   | Z   | D | с |
| dest    |           | 0                      | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             | - | - | -   | -    | 0   | 0   | - | - |
| src     |           | 0                      | 0               |                              | 0                            | 0           | 0           |                           |                            |                             | _ |   | _   | _    | 0   | 0   |   | _ |
| dest    |           | 0                      | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             | - | - | -   | -    |     |     | - | - |
| src     |           | 0                      | 0               |                              | 0                            | 0           | 0           |                           |                            |                             | - |   |     | _    | 0   | 0   |   | _ |
| dest    |           | 0                      | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             |   | Ľ |     |      |     |     | - |   |

|         |           |               |                 | Ado                          | dressi                       | ng          |             |                           |                            |                             |   |   | Fla | ag c | han | ge |   |   |
|---------|-----------|---------------|-----------------|------------------------------|------------------------------|-------------|-------------|---------------------------|----------------------------|-----------------------------|---|---|-----|------|-----|----|---|---|
|         |           | Spe<br>instru |                 |                              |                              |             |             |                           |                            |                             |   |   |     |      |     |    |   |   |
| Operand | Immediate | Absolute      | Register direct | Address register<br>indirect | Address register<br>relative | SB relative | FB relative | Stack pointer<br>relative | Control register<br>direct | Program counter<br>relative | U | I | 0   | в    | S   | Z  | D | С |
| src     |           | 0             | 0               | 0                            | 0                            | ο           | 0           |                           |                            |                             | - | - | -   | -    | -   | -  | - | - |
| src     |           | 0             | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             | - | - | -   | -    | -   | -  | - | - |
| src     |           | 0             | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             | - | - | -   | -    | -   | -  | - | - |



## High-level language and OS support

| Mnemonic |             | Explanation            |
|----------|-------------|------------------------|
| ENTER    | src         | Generates stack frame. |
| EXITD    | src         | Frees stack frame.     |
| LDCTX    | abs16,abs24 | Restores context.      |
| STCTX    | abs16,abs24 | Saves context.         |

|                     |           |          |                 | Ad                           | ldress                       | ing         |             |                           | _                          |                             | Flag change |   |   |   |   |   |   |   |  |  |  |
|---------------------|-----------|----------|-----------------|------------------------------|------------------------------|-------------|-------------|---------------------------|----------------------------|-----------------------------|-------------|---|---|---|---|---|---|---|--|--|--|
|                     |           |          | Ge              | eneral                       | instru                       | ction       |             | -                         | Sp<br>instr                |                             |             |   |   |   |   |   |   |   |  |  |  |
| Operand             | Immediate | Absolute | Register direct | Address register<br>indirect | Address register<br>relative | SB relative | FB relative | Stack pointer<br>relative | Control register<br>direct | Program counter<br>relative | U           | I | 0 | В | S | z | D | с |  |  |  |
| src                 | 0         |          |                 |                              |                              |             |             |                           |                            |                             | -           | - | - | I | - | - | - | - |  |  |  |
| src                 |           | 0        | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             | -           | - | - | - | - | - | - | - |  |  |  |
| abs16* <sup>∞</sup> |           |          |                 |                              |                              |             |             |                           |                            |                             |             |   |   |   |   |   |   |   |  |  |  |
| abs24 <sup>*</sup>  |           |          |                 |                              |                              |             |             |                           |                            |                             | Γ-          | - | - | - | - | - | - | - |  |  |  |
| abs16 <sup>*</sup>  |           |          |                 |                              |                              |             |             |                           |                            |                             |             |   |   |   |   |   |   |   |  |  |  |
| abs24 <sup>*</sup>  |           |          |                 |                              |                              |             |             |                           |                            |                             | Ι-          | - | - | - | - | - | - | - |  |  |  |

\*w For abs16, set the RAM address in which the task number is stored; for abs24, set the start address of table data.



## Other

| Mnemonic     | Explanation                                                                |
|--------------|----------------------------------------------------------------------------|
| BRK          | Generate BRK interrupt.                                                    |
| BRK2         | Debugger-only interrupt, whose use in user program is therefore inhibited. |
| FCLR dest    | Clears flags in flag register to 0.                                        |
| FREIT        | Returns from interrupt routine after fast interrupt request.               |
| FSET         | Sets flags in flag register to 1.                                          |
| INT          | Generates software interrupt.                                              |
| INTO         | Generates overflow interrupt when O (overflow) flag = 1.                   |
| LDC src,dest | Transfers src to dedicated register indicated by dest.                     |
| LDIPL src    | Transfers src to IPL.                                                      |
| NOP          | No operation.                                                              |
| REIT         | Returns from interrupt routine.                                            |
| STC src,dest | Transfers from dedicated register indicated by src to dest.                |
| UND          | Generates undefined instruction interrup.                                  |
| WAIT         | Stops executing program.                                                   |

|         |           |          |                 |                              |                              | Fla         | ng c        | han                       | ge                         |                             |                                                             |             |         |             |             |              |          |   |
|---------|-----------|----------|-----------------|------------------------------|------------------------------|-------------|-------------|---------------------------|----------------------------|-----------------------------|-------------------------------------------------------------|-------------|---------|-------------|-------------|--------------|----------|---|
|         |           |          | Ger             | neral i                      | nstruc                       | tion        |             |                           |                            | ecial<br>uction             |                                                             |             |         |             |             |              |          |   |
| Operand | Immediate | Absolute | Register direct | Address register<br>indirect | Address register<br>relative | SB relative | FB relative | Stack pointer<br>relative | Control register<br>direct | Program counter<br>relative | U                                                           | I           | 0       | В           | S           | Z            | D        | с |
|         |           |          |                 |                              |                              |             |             |                           |                            |                             | 0                                                           | 0           | -       | -           | -           | -            | 0        | - |
|         |           |          |                 |                              |                              |             |             |                           |                            |                             | 0                                                           | 0           | -       | -           | -           | -            | 0        | - |
| dest    |           |          |                 |                              |                              |             |             |                           | 0                          |                             |                                                             |             | ted fla |             |             |              |          |   |
|         |           |          |                 |                              |                              |             |             |                           |                            |                             |                                                             | Becon       |         |             |             |              |          |   |
| dest    |           |          |                 |                              |                              |             |             |                           |                            |                             |                                                             | Se          | ected   | flag is     | set to      | 1.           |          |   |
| src     | O⁺x       |          |                 |                              |                              |             |             |                           |                            |                             | 0                                                           | 0           | -       | 1           | -           | -            | 0        | - |
|         |           |          |                 |                              |                              |             |             |                           |                            |                             | 0                                                           | 0           | -       | -           | -           | -            | 0        | - |
| src     | 0         | 0        | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             | - Fl                                                        | l<br>ag cha | indes   | l<br>only w | l<br>Ihen d | l I<br>estis | I<br>FIG |   |
| dest    |           |          |                 |                              |                              |             |             |                           | O⁵y                        |                             |                                                             |             | lingoo  |             |             |              | L.       |   |
| src     | O⁺z       |          |                 |                              |                              |             |             |                           |                            |                             | -                                                           | -           | -       | -           | -           | -            | -        | - |
|         |           |          |                 |                              |                              |             |             |                           |                            |                             | -                                                           | -           | -       | -           | -           | -            | -        | - |
|         |           |          |                 |                              |                              |             |             |                           |                            |                             | Returns to FLG state before interrupt request was accepted. |             |         |             |             |              |          |   |
| src     | О⁺у       |          |                 |                              |                              |             |             |                           |                            |                             |                                                             |             |         |             |             |              |          |   |
| dest    |           | 0        | 0               | 0                            | 0                            | 0           | 0           |                           |                            |                             | - 1                                                         | -           | -       | -           | -           | -            | -        | - |
|         |           |          |                 |                              |                              |             |             |                           |                            |                             | 0                                                           | 0           | -       | -           | -           | -            | 0        | - |
|         |           |          |                 |                              |                              |             |             |                           |                            |                             | -                                                           | -           | -       | -           | -           | -            | -        | - |

\*x #IMM6 specifies a software interrupt number.

\*y Any dedicated register except the PC register can be selected.

\*z The range of possible values is 0 < #IMM3 < 7.


**KENESAS** 

Transfers normally are performed in bytes or words. There are 14 transfer instructions available. Included among these are a 4-bit transfer instruction that transfers only 4 bits, a conditional store instruction that is combined with conditional branch, and a string instruction that transfers data collectively.

This section explains these three characteristic instructions of the M16C/80 series among its data transfer-related instructions.

# 4 Bit Transfer Instruction

This instruction transfers 4 high-order or low-order bits of an 8-bit register or memory. This instruction can be used for generating unpacked BCD code or I/O port input/output in 4 bits. The mnemonic placed in Dir varies depending on whether the instruction is used to transfer high-order or low-order 4 bits. When using this instruction, <u>be sure to use ROL</u> for src or dest.

#### Table 2.6.5 4 Bit Transfer Instruction

| Mnemonic       | Descript                         | ion Format                                       | Explanation                                                                                                                                                                                                                                                  |
|----------------|----------------------------------|--------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MOV <i>Dir</i> | MOVHH<br>MOVHL<br>MOVLH<br>MOVLL | src,dest4<br>src,dest4<br>src,dest4<br>src,dest4 | Transfer<br>high-order bits: src $\rightarrow$ 4 high-order bits: dest<br>high-order bits: src $\rightarrow$ 4 low-order bits: dest<br>low-order bits: src $\rightarrow$ 4 high-order bits: dest<br>low-order bits: src $\rightarrow$ 4 low-order bits: dest |

Note: Either src or dest must always be R0L.



# **Conditional Store Instruction**

This is a conditional transfer instruction that uses the Z flag state as the condition of transfer. This instruction allows the user to perform condition determination and data transfer in one instruction. There are three types of conditional store instructions: STZ, STNZ, and STZX. Figure 2.6.3 shows an example of how the instruction works.

#### Table 2.6.6 Conditional Store Instruction

| Mnemonic | Description Format  | Explanation                                                                              |
|----------|---------------------|------------------------------------------------------------------------------------------|
| STZ      | STZ src,dest        | Transfers src to dest when Z flag = 1.                                                   |
| STNZ     | STNZ src,dest       | Transfers src to dest<br>when Z flag = 0.                                                |
| STZX     | STZX src1,src2,dest | Transfers src1 to dest<br>when Z flag = 1.<br>Transfers src2 to dest<br>when Z flag = 0. |







# **String Instruction**

This instruction transfers data collectively. Use it for transferring blocks and clearing RAM. Set the source address, destination address, and transfer count in each register before executing the instruction, as shown in Figure 2.6.4. Data is transferred in bytes or words. Figure 2.6.5 shows an example of how the string instruction works.



\*a:SMOVU instruction continues transferring string until 0 is detected in the source data to be transferred.

#### Figure 2.6.4 Setting registers for string instructions

#### Table 2.6.7 String Instruction

| Mnemonic | Description<br>Format | Explanation                                                                          |
|----------|-----------------------|--------------------------------------------------------------------------------------|
| SIN      | SIN.B<br>SIN.W        | Transfers string in address incrementing direction (source of transfer fixed).       |
| SOUT     | SOUT.B<br>SOUT.W      | Transfers string in address incrementing direction (destination of transfer fixed).  |
| SMOVB    | SMOVB.B<br>SMOVB.W    | Transfers string in address decrementing direction.                                  |
| SMOVF    | SMOVF.B<br>SMOVF.W    | Transfers string in address incrementing direction.                                  |
| SMOVU    | SMOVU.B<br>SMOVU.W    | Continues transferring string in address incrementing direction until 0 is detected. |
| SSTR     | SSTR.B<br>SSTR.W      | Stores string in address incrementing direction.                                     |



# RENESAS





# 2.6.4 Arithmetic Instructions

There are 39 arithmetic instructions available. This section explains the characteristic arithmetic instructions of the M16C/80 series.

#### Multiply Instruction

Multiply instructions are classified into signed multiply instructions, extended signed multiply instructions, and unsigned multiply instructions. The signed multiply instructions and unsigned multiply instructions allow the size to be specified. When .B is specified, operation is performed in 8 bits, i.e., (8 bits) x (8 bits) = (16 bits). When .W is specified, operation is performed in 16 bits, i.e., (16 bits) x (16 bits) = (32 bits).

When .B is specified, address registers cannot be used for both src and dest. Note also that the flag does not change in multiply instructions. An example of how multiply instructions operate is shown in Figure 2.6.7.



#### Table 2.6.8 Multiply Instruction



## **Divide Instruction**

There are three types of divide instructions: two signed divide instructions and one unsigned divide instruction. All these three instructions allow the user to specify the desired size. When .B is specified, calculation is performed in  $(16 \text{ bits}) \div (8 \text{ bits}) = (8 \text{ bits})...$  (Remainder in 8 bits); when .W is specified, calculation is performed in  $(32 \text{ bits}) \div (16 \text{ bits}) = (16 \text{ bits})...$  (Remainder in 16 bits). In divide instructions, the O flag changes state when the result overflows or a divide by 0 is attempted. An example of how divide instructions operate is shown in Figure 2.6.8.

#### Table 2.6.9 Divide Instruction





#### Difference between DIV and DIVX Instructions

Both DIV and DIVX are signed divide instructions. The difference between these two instructions is the sign of the remainder.

As shown in Table 2.6.10, the sign of the remainder deriving from the DIV instruction is the same as that of the dividend. With the DIVX instruction, however, the sign is the same as that of the divisor.

#### Table 2.6.10 Difference between DIV and DIVX Instructions

|      | 33 ÷ 4 = 8 1       |                                                                |
|------|--------------------|----------------------------------------------------------------|
| DIV  | 33 ÷ (-4) = 8 1    | The sign of the remainder is the same as that of the dividend. |
|      | -33 ÷ 4 = 8 … (-1) |                                                                |
|      | 33 ÷ 4 = 8 1       |                                                                |
| DIVX | 33 ÷ (-4) = 9 (-3) | The sign of the remainder is the same as that of the divisor.  |
|      | -33 ÷ 4 = -9 3     |                                                                |



# **Decimal Add Instruction**

There are two types of decimal add instructions: one with a carry and the other without a carry. The S, Z, and C flags change state when the decimal add instruction is executed. Figure 2.6.9 shows an example of how these instructions operate.

| Mnemonic    | Description Format                                                                                                                | Explanation                                                                                                                      |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|
| DADD        | DADD.B src,dest<br>DADD.W src,dest                                                                                                | Add in decimal not including carry.                                                                                              |
| DADC        | DADC.B src,dest<br>DADC.W src,dest                                                                                                | Add in decimal including carry.                                                                                                  |
| DADD 2digit | s $62 + 50 = 112$<br>10's 1's<br>place place<br>6 2<br>+ 5 0<br>C flag                                                            | 4digits $1234 + 9000 = 10234$<br>1000's 100's 10's 1's<br>place place place place<br>1 2 3 4<br>+ 9 0 0 0<br>1 0 2 3 4<br>C flag |
| DADC 2digi  | ts $62 + 30 + C \operatorname{flag} 1 =$<br>10's 1's<br>place place<br>6 2<br>3 0<br>+ C \operatorname{flag} 1<br>0 9 3<br>C flag | 93 4digits $1234 + 9000 + C \text{ flag} \boxed{1} = 10234$<br>1000's 100's 10's 10's 1's 1's 1's 1's 1's 1's 1's 1's 1's 1      |



# **Decimal Subtract Instruction**

There are two types of decimal subtract instructions: one with a borrow and the other without a borrow.

The S, Z, and C flags change state when the decimal subtract instruction is executed. Figure 2.6.10 shows an example of how these instructions operate.

| Mnemonic Description Format |                                                                                                                                                   | Explanation                                                                                                                                                                                                                                                                                                                                                              |
|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SUB                         | DSUB.B src,dest<br>DSUB.W src,dest                                                                                                                | Subtract in decimal not including borrow.                                                                                                                                                                                                                                                                                                                                |
| SBB                         | DSBB.B src,dest<br>DSBB.W src,dest                                                                                                                | Subtract in decimal including borrow.                                                                                                                                                                                                                                                                                                                                    |
| DSUB 2digit                 | s 78 - 11 = 67<br>10's 1's<br>place place<br>7 8<br>- 1 1<br>C flag                                                                               | 4digits 1111 - 1234 = 9877<br>1000's 100's 10's 1's<br>place place place place<br>1 1 1 1 1<br>- 1 2 3 4<br>0 9 8 7 7<br>C flag                                                                                                                                                                                                                                          |
| DSBB 2digits                | $78 - 11 - C \operatorname{flag} 1 = 67$ $10's  1's$ $place  place$ $7  8$ $1  1$ $-  \overline{C}\operatorname{flag}  0$ $C \operatorname{flag}$ | $\begin{array}{r} \text{4digits} & 1234 - 1111 - C \text{ flag} 0 = 012 \\ 1000'\text{s} & 100'\text{s} & 10'\text{s} & 1'\text{s} \\ \text{place place place place place} \\ \hline 1 & 1 & 1 & 1 \\ \hline 1 & 2 & 3 & 4 \\ \hline \hline 1 & 2 & 3 & 4 \\ \hline \hline \hline \hline \hline \hline \\ \hline 0 & 9 & 8 & 7 & 6 \\ \hline C \text{ flag} \end{array}$ |

#### Table 2.6.12 Decimal Subtract Instruction

# **Sum of Products Calculate Instruction**

This instruction calculates a sum of products and if an overflow occurs during calculation, generates an overflow interrupt. Set the multiplicand address, multiplier address, and sum of products calculation count in each register as shown in Figure 2.6.11. Figure 2.6.12 shows an example of how the sum-of-products calculate instruction works.

|                         |            |    | A0 |
|-------------------------|------------|----|----|
| Multiplicand address    |            |    | 24 |
|                         |            |    | A1 |
| Multiplier address      |            |    | 24 |
|                         |            |    | R3 |
| Sum of products calcula | tion count |    | 16 |
|                         | R1         | R2 | R0 |
| Calculation result      | 16         | 16 | 16 |

#### Figure 2.6.11 Setting registers for sum-of-products calculation instruction

| Table 2.6.13 S | Sum of Products | Calculate | Instruction |
|----------------|-----------------|-----------|-------------|
|----------------|-----------------|-----------|-------------|

| Mnemonic | Description Format | Explanation                                                                                                               |
|----------|--------------------|---------------------------------------------------------------------------------------------------------------------------|
| RMPA     | RMPA.B<br>RMPA W   | Calculates a sum of products using A0 as<br>multiplicand address, A1 as multiplier<br>address, and R3 as operation count. |

Note1:If an overflow occurs during calculation, the overflow flag(O flag) is set to 1 before terminating the calculation.

Note2:If an interrupt is requested during calculation, the sum of products calculation count is subtracted after completing the addition in progress before accepting the interrupt request.

RMPA.W



Figure 2.6.12 Typical operation of sum-of-products calculation instruction

# MAX, MIX, and CLIP instructions

The M16C/80 has three instructions that allow the lower-limit and upper-limit values of data to be set in one instruction. The CLIP instruction is a combination of MAX and MIN instructions. In these instructions, the flag does not change. An example of how these instructions operate is shown in Figure 2.6.13.

| Mnemonic | Description Format                             | Explanation                                                                                                                                                                                                                       |
|----------|------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| МАХ      | MAX.B src,dest<br>MAX.W src,dest               | Compares src and dest with sign included and transfers src to dest when src is greater than dest.                                                                                                                                 |
| MIN      | MIN.B src,dest<br>MIN.W src,dest               | Compares src and dest with sign included and transfers src to dest when src is smaller than dest.                                                                                                                                 |
| CLIP     | CLIP.B src1,src2,dest<br>CLIP.W src1,src2,dest | Compares src and dest with sign included and transfers src1 to dest when src1 is greater than dest; next, transfers src2 to dest when src2 is smaller than dest. Consequently, nothing is stored if src1 $\leq$ dest $\leq$ src2. |





# SCcnd instruction

The M16C/80 has an instruction that stores a 1 or 0 in dest (1 word) depending on the flag content of the flag register. An example of how this instruction operates is shown in Figure 2.6.14.

Table 2.6.15 SCcnd instruction

| Mnemonic   | Description      | Format | Explanation                                                                  |
|------------|------------------|--------|------------------------------------------------------------------------------|
| SCcnd dest | SCGEU/C          | dest   | If C=1, dest $\leftarrow$ 1;otherwise, dest $\leftarrow$ 0                   |
|            | SC <i>LTU/NC</i> | dest   | if C=0, dest $\leftarrow$ 1;otherwise, dest $\leftarrow$ 0                   |
|            | SCEQ/Z           | dest   | if Z=1, dest $\leftarrow$ 1;otherwise, dest $\leftarrow$ 0                   |
|            | SCNE/NZ          | dest   | if Z=0, dest $\leftarrow$ 1;otherwise, dest $\leftarrow$ 0                   |
|            | SCGTU            | dest   | if C $\Lambda$ Z=1, dest $\leftarrow$ 1;otherwise, dest $\leftarrow$ 0       |
|            | SCLEU            | dest   | If C $\Lambda$ Z=0, dest $\leftarrow$ 1;otherwise, dest $\leftarrow$ 0       |
|            | SC <i>PZ</i>     | dest   | If S=0, dest $\leftarrow$ 1;otherwise, dest $\leftarrow$ 0                   |
|            | SC <i>N</i>      | dest   | If S=1, dest $\leftarrow$ 1;otherwise, dest $\leftarrow$ 0                   |
|            | SCGE             | dest   | If S $\forall$ O=0, dest $\leftarrow$ 1;otherwise, dest $\leftarrow$ 0       |
|            | SCLE             | dest   | If (S $\forall$ O) V Z=1, dest $\leftarrow$ 1;otherwise, dest $\leftarrow$ 0 |
|            | SCGT             | dest   | If (S $\forall$ O) V Z=0, dest $\leftarrow$ 1;otherwise, dest $\leftarrow$ 0 |
|            | SCLT             | dest   | If S $\forall$ O=1, dest $\leftarrow$ 1;otherwise, dest $\leftarrow$ 0       |
|            | SCO              | dest   | If O=1, dest $\leftarrow$ 1;otherwise, dest $\leftarrow$ 0                   |
|            | SCNO             | dest   | If O=0, dest $\leftarrow$ 1;otherwise, dest $\leftarrow$ 0                   |





# 2.6.5 Branch Instructions

There are ten branch instructions available with the M16C/80 series. This section explains some characteristic branch instructions among these.

#### **Unconditional Branch Instruction**

This instruction causes control to jump to label unconditionally. The jump distance specifier normally is omitted. When this specifier is omitted, the assembler optimizes the jump distance when assembling the program. Figure 2.6.16 shows an example of how the unconditional branch instruction works.

#### Table 2.6.16 Unconditional Branch Instruction

| Mnemonic | Description Format               |                                  | Explanation     |
|----------|----------------------------------|----------------------------------|-----------------|
| JMP      | JMP.S<br>JMP.B<br>JMP.W<br>JMP.A | label<br>label<br>label<br>label | Jumps to label. |

Range of jump:

.S Jump in PC relative addressing from +2 to +9 (operand : 0 byte)

.B Jump in PC relative addressing from -127 to +128 (operand : 1 byte)

.W Jump in PC relative addressing from -32,767 to +32,768 (operand : 2 bytes)

.A Jump in 20 bit absolute addressing (operand : 3 bytes)





# Indirect Branch Instruction

This instruction indirectly branches to the address indicated by src.

When the branch distance specifier ".W" is specified, the program branches to the address derived by adding src to the start address of the JMPI instruction, with the sign included. If src is memory, the necessary memory size is 2 bytes. When the branch distance specifier ".A" is specified, the program branches to the address indicated by src. If src is memory, the necessary memory size is 3 bytes. This instruction always requires that a branch distance specifier be specified. An example of how the indirect branch instruction operates is shown in Figure 2.6.16.





# Special Page Branch Instruction

This instruction branches to the address derived by adding FF0000H to the address that has been set in the relevant special page vector table. The address range in which branch occurs is FF0000H to FFFFFFH. Because the special page branch instruction is only 2 bytes in size, it helps to increase ROM efficiency.

Use a special page number or label to specify the target address. Make sure the special page number is prefixed by "#," and that label is prefixed by "\". When label is used for address specification, the assembler calculates the special page number. An example of how the special page branch instruction operates is shown in Figure 2.6.17.



### Table 2.6.18 Special Page Branch Instruction



# **Conditional Branch Instruction**

This instruction examines flag status with respect to the conditions listed below and causes control to branch if the condition is true or executes the next instruction if the condition is false. Figure 2.6.18 shows an example of how the conditional branch instruction works.

| Mnemonio | c Description Format                                                | Explana                 | ition                             |  |
|----------|---------------------------------------------------------------------|-------------------------|-----------------------------------|--|
| JCnd     | JCnd label Jumps to label if condition or executes next instruction |                         |                                   |  |
| Cnd      | True/false determining conditions (14 conditions)                   |                         |                                   |  |
| GEU/C    | C = 1                                                               |                         | Equal or greater/ Carry flag = 1. |  |
| GTU      | C = 1 & Z = 0                                                       |                         | Unsigned and greater.             |  |
| EQ/Z     | Z = 1                                                               |                         | Equal/ Zero flag = 1.             |  |
| N        | S = 1                                                               |                         | Negative.                         |  |
| LE       | (z = 1)   (S = 1 & O = 0)                                           | (S = 0 & O = 1)         | Equal or signed and smaller.      |  |
| 0        | O = 1                                                               |                         | Overflow flag = 1.                |  |
| GE       | (S =1 & O = 1)   (S = 0 & O = 0)                                    |                         | Equal or signed and greater.      |  |
| LTU/NC   | C = 0                                                               |                         | Smaller/ Carry flag = 0.          |  |
| LEU      | C = 0   Z = 1                                                       |                         | Equal or smaller.                 |  |
| NE/NZ    | Z = 0                                                               |                         | Not equal/ Zero flag = 0.         |  |
| PZ       | S = 0                                                               |                         | Positive or zero.                 |  |
| GT       | (S = 1 & O = 1 & Z = 0)                                             | (S = 0 & O = 0 & Z = 0) | Signed and greater.               |  |
| NO       | O = 0                                                               |                         | Overflow flag = 0.                |  |
| LT       | (S =1 & O = 0)   (S = 0 &                                           | & O = 1)                | Signed and smaller.               |  |

#### Table 2.6.19 Conditional Branch Instruction

Range of jmp : -127 to +128





JEQ LABEL1 (Jumps to LABEL1 if Z flag = 1)

Figure 2.6.18 Typical operation of conditional branch instruction

# Add (Subtract) & Conditional Branch Instruction

This instruction is convenient for determining whether repeat processing is terminated or not. The values added or subtracted by this instruction are limited to 4-bit immediate. Specifically, the value is -8 to +7 for the ADJNZ instruction, and -7 to +8 for the SBJNZ instruction. The range of addresses to which control can jump is -126 to +129 from the start address of the ADJNZ/SBJNZ instruction. Figure 2.6.8 shows an example of how the add (subtract) & conditional branch instruction works.

#### Table 2.6.20 Add (Subtract) & Conditional Branch Instruction

| Mnemonic | Desci   | ription Format   | Explanation                       |
|----------|---------|------------------|-----------------------------------|
| ADJNZ    | ADJNZ.B | #IMM4,dest,label | Adds immediate to dest.           |
|          | ADJNZ.W | #IMM4,dest,label | Jump to label if result is not 0. |
| SBJNZ    | SBJNZ.B | #IMM4,dest,label | Subtracts immediate from dest.    |
|          | SBJNZ.W | #IMM4,dest,label | Jump to label if result is not 0. |

Note1:#IMM can only be a 4 bit immediate (-8 to +7 for the ADJNZ instruction ; -7 to +8 for the SBJNZ instruction).

Note2:The range of addresses to which control can jump in PC relative addressing is -126 to +129

ADJNZ.W #2,R0,LOOP SBJNZ.W #2,R0,LOOP



from the start address of the ADJNZ / SBJNZ instructions. Figure 2.6.19 Typical operations of add (subtract) & conditional branch instructions



# 2.6.6 Bit Instructions

This section explains the bit instructions of the M16C/80 series.

#### Logical Bit Manipulating Instruction

This instruction ANDs or ORs a specified register or memory bit and the C flag and stores the result in the C flag. Figure 2.6.12 shows an example of how the logical bit manipulating instruction works.

| Table 2.6.21 | Logical Bit | Manipulating | Instruction |
|--------------|-------------|--------------|-------------|
|--------------|-------------|--------------|-------------|

| Mnemonic | Description Forma | at | Explanation                                                              |
|----------|-------------------|----|--------------------------------------------------------------------------|
| BAND     | BAND src          | ,  | C flag $\leftarrow$ src $\land$ C flag ;Bitwise AND.                     |
| BNAND    | BNAND src         | ;  | C flag $\leftarrow$ src $\Lambda$ C flag ;Inverted bitwise AND.          |
| BNOR     | BNOR src          | ;  | C flag $\leftarrow$ src V C flag ;Inverted bitwise OR.                   |
| BNXOR    | BNXOR src         | ;  | C flag $\leftarrow$ src $\forall$ C flag ;Inverted bitwise exclusive OR. |
| BOR      | BOR src           | ;  | C flag $\leftarrow$ src V C flag ;Bitwise OR.                            |
| BXOR     | BXOR src          | ;  | C flag $\leftarrow$ src $\forall$ C flag ;Bitwise exclusive OR.          |





# **Conditional Bit Transfer Instruction**

This instruction transfers a bit from depending on whether a condition is met. If the condition is true, it transfers "1"; if the condition is false, it transfers "0". In all cases, a flag is used to determine whether the condition is true or false. This instruction must be preceded by an instruction that causes the flag to change. Figure 2.6.21 shows an example of how the conditional bit transfer instruction works.

| Mnemonic | Descri<br>Forn |           | Explanation                                                      |
|----------|----------------|-----------|------------------------------------------------------------------|
| BMCnd    | BMCnd<br>BMCnd | dest<br>C | Transfers "1" if condition is true or "0" if condition is false. |

| Cnd    | True/false determining conditions (14 conditions) |                                   |  |  |  |
|--------|---------------------------------------------------|-----------------------------------|--|--|--|
| GEU/C  | C = 1                                             | Equal or greater/ Carry flag = 1. |  |  |  |
| GTU    | C = 1 & Z = 0                                     | Unsigned and greater.             |  |  |  |
| EQ/Z   | Z = 1                                             | Equal/ Zero flag = 1.             |  |  |  |
| N      | S = 1                                             | Negative.                         |  |  |  |
| LE     | (z = 1)   (S = 1 & O = 0)   (S = 0 & O = 1)       | Equal or signed and smaller.      |  |  |  |
| 0      | O = 1                                             | Overflow flag = 1.                |  |  |  |
| GE     | (S =1 & O = 1)   (S = 0 & O = 0)                  | Equal or signed and greater.      |  |  |  |
| LTU/NC | C = 0                                             | Smaller/ Carry flag = 0.          |  |  |  |
| LEU    | C = 0   Z = 1                                     | Equal or smaller.                 |  |  |  |
| NE/NZ  | Z = 0                                             | Not equal/ Zero flag = 0.         |  |  |  |
| PZ     | S = 0                                             | Positive or zero.                 |  |  |  |
| GT     | (S = 1 & O = 1 & Z = 0)   (S = 0 & O = 0 & Z = 0) | Signed and greater.               |  |  |  |
| NO     | O = 0                                             | Overflow flag = 0.                |  |  |  |
| LT     | (S =1 & O = 0)   (S = 0 & O = 1)                  | Signed and smaller.               |  |  |  |

BMGEU 3,1000H[SB]







# 2.6.7 Sign-extension instruction

The sign-extension instruction extends bit length by substituting the sign bit for the bits to be extended. This section explains about the sign-extension instruction.

#### **Sign-extension instruction**

The sign-extension instruction comes in two types: a sign-extension instruction that extends bit length with the MSB (most significant bit), and a zero-extension instruction that extends bit length by forcibly filling the most significant bit with 0. When the size specifier ".B" is specified, the sign-extension instruction extends bit length to 16 bits; when the size specifier ".W" is specified, it extends bit length to 32 bits.

The zero-extension instruction extends bit length to 16 bits. An example of how the sign-extension instruction operates is shown in Figure 2.6.22.

#### Table 2.6.23 Sign-extension instruction

| Mnemonic | Description Format |          | Explanation                                                 |
|----------|--------------------|----------|-------------------------------------------------------------|
|          | EXTS.B             | dest     | Sign-extends dest to 16 bits.                               |
| EXTS     | EXTS.W             | dest     | Sign-extends dest to 32 bits.                               |
|          | EXTS.B             | src,dest | Sign-extends src before transferring it to dest.            |
| EXTZ     | EXTZ               | src,dest | Zero-extends src to 16 bits before transferring it to dest. |



Figure 2.6.22 Typical operation of sign-extension instruction



# 2.6.8 Index instruction

The M16C/80 has index instructions to allow arrays to be referenced efficiently when programming in C language. Index instructions make it possible to specify array elements without address calculation. This section explains about index instructions.

#### Index instruction

The index instruction modifies addressing of the next instruction. Index instructions classified by type are listed in Table 2.6.24. An example of how the index instruction operates is shown in Figure 2.6.23.

#### Table 2.6.24 Index instruction

| Туре          | Function                                                            |
|---------------|---------------------------------------------------------------------|
| B<br>BD<br>BS | Modifies addressing of the next instruction in units of bytes.      |
| W<br>WD<br>WS | Modifies addressing of the next instruction in units of words.      |
| L<br>LD<br>LS | Modifies addressing of the next instruction in units of long words. |

| Mnemonic             | Description              | Format     | Explanation                                                                                                                                                                                                                              |
|----------------------|--------------------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INDEXB               | INDEXB.B<br>INDEXB.W     | src<br>src | The content of src of the INDEXB instruction is added to the address indicated by src, dest of the next instruction to be executed, with the sign not included, to find the effective address.                                           |
| INDEXBD              | INDEXBD.B<br>INDEXBD.W   | SIC<br>SIC | The content of src of the INDEXB instruction is added to the address indicated by dest (src in some instructions) of the next instruction to be executed, with the sign not included, to find the effective address.                     |
| INDEXBS              | INDEXBS.B<br>INDEXBS.W   | src<br>src | The content of src of the INDEXB instruction is added to the address indicated by src of the next instruction to be executed, with the sign not included, to find the effective address.                                                 |
| INDEXW <sup>*a</sup> | INDEXB.B<br>INDEXB.W     | SIC<br>SIC | Twice the content of src of the INDEXW instruction is added to<br>the address indicated by src, dest of the next instruction to be<br>executed, with the sign not included, to find the effective<br>address.                            |
| INDEXWD*a            | INDEXWD.B<br>INDEXWD.W   | src<br>src | Twice the content of src of the INDEXB instruction is added to<br>the address indicated by dest (src in some instructions) of the<br>next instruction to be executed, with the sign not included, to find<br>the effective address.      |
| INDEXWS*ª            | INDEXWS.B<br>INDEXWS.W   | SIC<br>SIC | Twice the content of src of the INDEXB instruction is added to<br>the address indicated by src of the next instruction to be<br>executed, with the sign not included, to find the effective<br>address.                                  |
| INDEXL' <sup>b</sup> | INDEXL.B<br>INDEXL.W     | src<br>src | Four times the content of src of the INDEXW instruction is added<br>to the address indicated by src, dest of the next instruction to be<br>executed, with the sign not included, to find the effective<br>address.                       |
| INDEXLD*             | INDEXLD.B<br>INDEXLD.W   | src<br>src | Four times the content of src of the INDEXB instruction is added<br>to the address indicated by dest (src in some instructions) of the<br>next instruction to be executed, with the sign not included, to find<br>the effective address. |
| INDEXLS <sup>®</sup> | INDEXLS.B<br>INDEXLS.W   | src<br>src | Four times the content of src of the INDEXB instruction is added<br>to the address indicated by src of the next instruction to be<br>executed, with the sign not included, to find the effective<br>address.                             |
| BITINDEX             | BITINDEX.B<br>BITINDEX.W | src<br>src | The bit as many bits apart as indicated by src of the BITINDEX instruction from bit 0 at the address indicated by src or dest of the next instruction to be executed, is the target to be operated on.                                   |

\*a : Corresponds to arrays arranged in units of words.

\*b : Corresponds to arrays arranged in units of long words.





## 2.6.9 High-level language and OS support instructions

The high-level language support instruction builds/frees a stack frame. The OS support instruction saves/restores task context. These instructions allow switching-over of complex processing or task context in high-level language to be executed by a single instruction.

#### **Building Stack Frame**

ENTER is an instruction to build a stack frame. Use #IMM to set bytes of the automatic variable area. Figure 2.6.24 shows an example of how this instruction works.

#### Table 2.6.25 Stack Frame Build Instruction





# **Deallocate Stack Frame**

The EXITD instruction deallocate the stack frame and returns control from the subroutine. It performs these operations simultaneously. Figure 2.6.25 shows an example of how the stack frame clean-up instruction works.





# **OS** support instruction

The STCTX instruction saves task context. The LDCTX instruction restores task context. A table of task context is shown in Figure 2.6.26. The register information that is set in the context table shows the type of register to be saved as context in a stack area. The SP correction value shows the size in bytes of the register to be transferred. The OS support instruction uses these two pieces of information to save and restore task context to and from a stack area.

#### Table 2.6.27 OS Support Instructions

| Mnemonic | Description Format       | Explanation            |
|----------|--------------------------|------------------------|
| STCTX    | STCTX abs16,abs24 (Note) | Saves task context.    |
| LDCTX    | LDCTX abs16,abs24        | Restores task context. |



Note : abs16 is a memory address which stored task number ( 8 bits ). abs 24 is a top address of context table.



# **Operation for Saving Context (STCTX instruction)**





# **Operation for Restoring Context (LDCTX instruction)**





# 2.7 Outline of Interrupt

This section explains the types of interrupt sources available with the M16C/80 group and the internal processing (interrupt sequence) performed after an interrupt request is accepted until an interrupt routine is executed. For details on how to use each interrupt and how to set, refer to Chapter 4.

## 2.7.1 Interrupt Sources and Vector addresses

The following explains the interrupt sources available with the M16C/80 group.

### Interrupt Sources in M16C/80 Group

Figure 2.7.1 shows the interrupt sources available with the M16C/80 group.

Hardware interrupts consist of six types of special interrupts such as reset and  $\overline{\text{NMI}}$  and various peripheral I/O interrupts<sup>(Note)</sup> that are dependent on built-in peripheral functions such as timers and external pins. Special interrupts are nonmaskable; peripheral I/O interrupts are maskable. Maskable interrupts are enabled and disabled by an interrupt enable flag (I flag), an interrupt priority level select bit, and the processor interrupt priority level (IPL).

Software interrupts generate an interrupt request by executing a software interrupt instruction. There are five types of software interrupts: INT instruction interrupt, BRK instruction interrupt, BRK2 instruction interrupt, overflow interrupt, and undefined instruction interrupt. Software interrupts are nonmaskable.



Note: Peripheral functions vary with each type of microcomputer used. For details about peripheral interrupts, refer to the data sheet and user's manual of your microcomputer.



#### Vector addresses

Figure 2.7.2 shows software interrupt and special interrupt vector addresses. Figure 2.7.3 shows hardware interrupt vector addresses. Before using these interrupts, set the start address of each relevant interrupt routine at these vector addresses.



Note 1: If the vector contents all are "FFH," the program branches to the address indicated by the vector of software interrupt number 0 in the variable vector table. Note 2: This area is inhibited against use by the user.

| Software interrupt number    | Vector table address<br>Address (L) to address (H) | Interrupt source                                                         | Remarks                 |  |
|------------------------------|----------------------------------------------------|--------------------------------------------------------------------------|-------------------------|--|
| Software interrupt number 0  | +0 to +3 (Note 1)                                  | BRK instruction                                                          | Cannot be masked I flag |  |
|                              |                                                    |                                                                          |                         |  |
| Software interrupt number 8  | +32 to +35 (Note 1)                                | DMA0                                                                     |                         |  |
| Software interrupt number 9  | +36 to +39 (Note 1)                                | DMA1                                                                     |                         |  |
| Software interrupt number 10 | +40 to +43 (Note 1)                                | DMA2                                                                     |                         |  |
| Software interrupt number 11 | +44 to +47 (Note 1)                                | DMA3                                                                     |                         |  |
| Software interrupt number 12 | +48 to +51 (Note 1)                                | Timer A0                                                                 |                         |  |
| Software interrupt number 13 | +52 to +55 (Note 1)                                | Timer A1                                                                 |                         |  |
| Software interrupt number 14 | +56 to +59 (Note 1)                                | Timer A2                                                                 |                         |  |
| Software interrupt number 15 | +60 to +63 (Note 1)                                | Timer A3                                                                 |                         |  |
| Software interrupt number 16 | +64 to +67 (Note 1)                                | Timer A4                                                                 |                         |  |
| Software interrupt number 17 | +68 to +71 (Note 1)                                | UART0 transmit                                                           |                         |  |
| Software interrupt number 18 | +72 to +75 (Note 1)                                | UART0 receive                                                            |                         |  |
| Software interrupt number 19 | +76 to +79 (Note 1)                                | UART1 transmit                                                           |                         |  |
| Software interrupt number 20 | +80 to +83 (Note 1)                                | UART1 receive                                                            |                         |  |
| Software interrupt number 21 | +84 to +87 (Note 1)                                | Timer B0                                                                 |                         |  |
| Software interrupt number 22 | +88 to +91 (Note 1)                                | Timer B1                                                                 |                         |  |
| Software interrupt number 23 | +92 to +95 (Note 1)                                | Timer B2                                                                 |                         |  |
| Software interrupt number 24 | +96 to +99 (Note 1)                                | Timer B3                                                                 |                         |  |
| Software interrupt number 25 | +100 to +103 (Note 1)                              | Timer B4                                                                 |                         |  |
| Software interrupt number 26 | +104 to +107 (Note 1)                              | INT5                                                                     |                         |  |
| Software interrupt number 27 | +108 to +111 (Note 1)                              | ĪNT4                                                                     |                         |  |
| Software interrupt number 28 | +112 to +115 (Note 1)                              | ĪNT3                                                                     |                         |  |
| Software interrupt number 29 | +116 to +119 (Note 1)                              | ĪNT2                                                                     |                         |  |
| Software interrupt number 30 | +120 to +123 (Note 1)                              | ÎNT1                                                                     |                         |  |
| Software interrupt number 31 | +124 to +127 (Note 1)                              | INTO                                                                     |                         |  |
| Software interrupt number 32 | +128 to +131 (Note 1)                              | Timer B5                                                                 |                         |  |
| Software interrupt number 33 | +132 to +135 (Note 1)                              | UART2 transmit/NACK (Note 2)                                             |                         |  |
| Software interrupt number 34 | +136 to +139 (Note 1)                              | UART2 receive/ACK (Note 2)                                               |                         |  |
| Software interrupt number 35 | +140 to +143 (Note 1)                              | UART3 transmit/NACK (Note 2)                                             |                         |  |
| Software interrupt number 36 | +144 to +147 (Note 1)                              | UART3 receive/ACK (Note 2)                                               |                         |  |
| Software interrupt number 37 | +148 to +151 (Note 1)                              | UART4 transmit/NACK (Note 2)                                             |                         |  |
| Software interrupt number 38 | +152 to +155 (Note 1)                              | UART4 receive/ACK (Note 2)                                               |                         |  |
| Software interrupt number 39 | +156 to +159 (Note 1)                              | Bus collision detection, start/stop condition detection (UART2) (Note 2) |                         |  |
| Software interrupt number 40 | +160 to +163 (Note 1)                              | Bus collision detection, start/stop condition detection (UART3) (Note 2) |                         |  |
| Software interrupt number 41 | +164 to +167 (Note 1)                              | Bus collision detection, start/stop condition detection (UART4) (Note 2) |                         |  |
| Software interrupt number 42 | +168 to +171 (Note 1)                              | A-D                                                                      |                         |  |
| Software interrupt number 43 | +172 to +175 (Note 1)                              | Key input interrupt                                                      |                         |  |
| Software interrupt number 44 | +176 to +179 (Note 1)<br>to                        | Software interrupt                                                       | Cannot be masked I flag |  |
| Software interrupt number 63 | +252 to +255 (Note 1)                              |                                                                          |                         |  |

Note 1: Address relative to address in interrupt table register (INTB). Note 2: When I<sup>2</sup>C mode is selected, NACK/ACK, start/stop condition detection interrupts are selected. The fault error interrupt is selected when SS pin is selected.

Figure 2.7.3 Hardware interrupt vector addresses



# 2.7.2 Variable vector table

The variable vector table is a 256-byte vector table that starts from the address indicated by the interrupt table register (INTB). (See Figure 2.7.3.) The vector table can be located in any area except the SFR area and the extended reserved area.

#### Variable vector table

One vector consists of 4 bytes, with each vector assigned software interrupt numbers 0 to 63. Using the INT instruction and a software interrupt number, it is possible to execute a peripheral I/O interrupt routine in a simulated manner. Figure 2.7.4 shows how the variable vector table is located in memory.



Figure 2.7.4 Example of how the variable vector table is located

# 2.7.3 Interrupt generation conditions and interrupt control register bit configuration

This section describes conditions under which an interrupt is accepted and the bit configuration of the interrupt control register.

#### Interrupt generation conditions

When an interrupt is requested, it is accepted when all of the following three conditions are met:

(1)Interrupt enable flag (I flag) = 1 (interrupt enabled)
(2)Processor interrupt level (IPL) < Interrupt priority level of the requested interrupt</li>
(3)Interrupt request bit (interrupt control register bit 3) = 1



# Bit configuration of the interrupt control register

Figure 2.7.5 shows the interrupt control register provided for each interrupt.



Note: This bit can only be accessed for reset (= 0), but cannot be accessed for set (= 1).



Figure 2.7.5 Bit configuration of the interrupt control register

Note 3: The symbols shown here are for the M16C/80 group. They vary with each microcomputer type used.

# 2.7.4 Interrupt acceptance timing and sequence

This section describes the interrupt acceptance timing and interrupt sequence.

## Interrupt acceptance timing

When an interrupt request occurs while executing an instruction, the priority of the requested interrupt is resolved after the instruction being executed finishes, and an interrupt sequence begins in the next cycle. The interrupt acceptance timing in this case is shown in Figure 2.7.6. However, if an interrupt request occurs when executing an string instruction (SCMPU, SIN, SMOVB, SMOVF, SMOVU, SSTR, or SOUT) or multiply/accumulate instruction (RMPA), the instruction being executed is suspended and an interrupt sequence is entered. The interrupt acceptance timing in this case is shown in Figure 2.7.7.

#### 1. Interrupt under normal condition



#### Figure 2.7.6 Interrupt acceptance timing 1

#### 2. Interrupt under exceptional condition

If an interrupt request is generated when executing one of the following instructions, the interrupt sequence occurs in the middle of that instruction execution.

- (1) String transfer instruction (SCMPU,SIN,SMOVB,SMOVF,SMOVU,SSTR,SOUT)
- (2) Sum-of-product calculating instruction (RMPA)
- Interrupt request generated



#### Figure 2.7.7 Interrupt acceptance timing 2



#### Interrupt sequence

The following explains an interrupt sequence from when an interrupt request is accepted to when an interrupt routine is executed.

- (1) The CPU reads address 000000H (or 000002H for fast interrupts) to get interrupt information (interrupt number, interrupt request level). The relevant interrupt request bit is then reset to 0.
- (2) The content of the flag register (FLG) immediately before the interrupt sequence begins is saved to an internal temporary register<sup>(Note)</sup> of the CPU.
- (3) The interrupt enable flag (I flag), debug flag (D flag), and stack pointer specification flag (U flag) are reset to 0. (However, the U flag does not change if an INT instruction of software interrupt numbers 32 to 63 was being executed when the interrupt occurred.) Thus, by the above operations...
  - (a)The stack pointer is forcibly made the interrupt stack pointer (ISP). (However, if an INT instruction of software interrupt numbers 32 to 63 was being executed when the interrupt occurred, the stack pointer (ISP or USP) that was active when the interrupt occurred is used.)
  - (b)Multiple interrupts are disabled.
  - (c)Single-step interrupt is disabled.
- (4) The content of the CPU's internal temporary register<sup>(Note)</sup> and that of the program counter (PC) are saved to the stack area. For fast interrupts, they are saved to the save flag register (SVF) and save PC register (SVP).
- (5) The interrupt priority level of the accepted interrupt is set in the processor interrupt priority level (IPL).

When the interrupt sequence is completed, instructions are executed beginning with the start address of the interrupt routine.



# 2.7.5 Interrupt priority

This section explains about interrupt priority.

# Interrupt priority

If two or more interrupt requests simultaneously are sampled active (= asserted), the interrupt with the highest priority among those interrupts is accepted. Maskable interrupts (peripheral I/O interrupts) can be assigned any desired priority by using the interrupt priority level select bits. However, when requested interrupts have the same priority level, the first interrupt requested is accepted, and the remaining other interrupts are accepted according to the priority<sup>(Note)</sup> that is set in hardware.

Nonmaskable interrupts such as a reset (handled as an interrupt of the highest priority) and a watchdog timer interrupt have their priorities set in hardware. The interrupt priorities set in hardware are shown in Figure 2.7.8.

Software interrupts are unaffected by interrupt priority. When an instruction is executed, the program always branches to the relevant interrupt routine.

Note: This priority varies with each type of microcomputer. Be sure to consult data sheets and user's manual.






# **Chapter 3**

# **Functions of Assembler**

- 3.1 Outline of AS308 System
- 3.2 Method for Writing Source Program

# 3.1 Outline of AS308 System

The AS308 system is a software system that supports development of programs for controlling the M16C/80 series single-chip microcomputers at the assembly language level. In addition to the assembler, the AS308 system comes with a linkage editor and a load module converter. This section explains the outline of AS308.

## Functions

- Relocatable assemble function
- Optimized code generating function
- Macro function
- High-level language source level debug function
- Various file generating function
- IEEE-695 format<sup>(Note 1)</sup> file generating function

## Configuration

The AS308 system consists of the following programs:

Assembler driver (as308)

This is an execution file to start up the macroprocessor and assembler processor. This assembler driver can process multiple assembly source files.

#### • Macroprocessor (mac308)

This program processes macro directive commands in the assembly source file and performs preprocessing for the assembly processor, thereby generating an intermediate file. This intermediate file is erased after processing by the assembler processor is completed.

#### Assembler processor (asp308)

This program converts the intermediate file generated by the macroprocessor into a relocatable module file.

#### • Linkage editor (In308)

This program links the relocatable module files generated by the assembler processor to generate an absolute module file.

#### • Load module converter (Imc308)(Note 2)

This program converts the absolute module file generated by the linkage editor into a machine language file that can be programmed into ROM.

#### • Librarian (lb308)

By reading in the relocatable module files, this program generates and manages a library file.

#### • Cross referencer (xrf308)

This program generates a cross reference file that contains definition of various symbols and labels used in the assembly source file created by the user.

#### • Absolute lister (abs308)

Based on the address information in the absolute module file, this program generates an absolute list file that can be output to a printer.

Note 1: IEEE stands for the Institute of Electrical and Electronics Engineers. Note 2: The load module converter is a program to convert files into the format in which they can be programmed into M16C/80 series ROMs.



## **Outline of Processing by AS308 System**





## Input/output Files Handled by AS308

The table below separately lists the input files and the output files handled by the AS308 system. Any desired file names can be assigned. However, if the extension of a file name is omitted, the AS308 system automatically adds a default file extension. These default extensions are shown in parenthesis in the table below.

| Table 3.1.1 | List of Input/output Files |
|-------------|----------------------------|
|-------------|----------------------------|

| Program Name                    | Input File Name (Extension)                             | Output File Name (Extension)                                                                 |
|---------------------------------|---------------------------------------------------------|----------------------------------------------------------------------------------------------|
| Assembler<br>as308              | Source file(.as30)<br>Include file(.inc)                | Relocatable module file(.r30)<br>Assembler list file(.lst)<br>Assembler error tag file(.atg) |
| Linkage editor<br>In308         | Relocatable module file(.r30)<br>Library file(.lib)     | Absolute module file(.x30)<br>Map file(.map)<br>Link error tag file(.ltg)                    |
| Load module converter<br>Imc308 | Absolute module file(.x30)                              | Motorola S format file(.mot)<br>Extended Intel HEX format<br>file(.hex)                      |
| Librarian<br>Ib308              | Relocatable module file(.r30)<br>Library file(.lib)     | Library file(.lib)<br>Relocatable module file(.r30)<br>Library list file(.lls)               |
| Cross referencer<br>xrf308      | Assemble source file(.a30)<br>Assembler list file(.lst) | Cross reference file(.xrf)                                                                   |
| Absolute lister<br>abs308       | Absolute module file(.x30)<br>Assembler list file(.lst) | Absolute list file(.als)                                                                     |

# 3.2 Method for Writing Source Program

This section explains the basic rules, address control, and directive commands that need to be understood before writing the source programs that can be processed by the AS308 system. For details about the AS308 system itself, refer to AS308 User's Manuals, "Operation Part" and "Programming Part".

## 3.2.1 Basic Rules

The following explains the basic rules for writing the source programs to be processed by the AS308 system.

## **Precautions on Writing Programs**

Pay attention to the following precautions when writing the source programs to be processed by the AS308 system:

- Do not use the AS308 system reserved words for names in the source program.
- Do not use a character string consisting of one of the AS308 system directive commands with the period removed, because such a character string could affect processing by AS308. They can be used in names without causing an error.
- Do not use system labels (the character strings that begin with ..) because they may be used for future extension of the AS308 system. When they are used in the source program created by the user, the assembler does not output an error.

## Character Set

The characters listed below can be used to write the assembly program to be processed by the AS308 system.

Uppercase English alphabets A B C D E F G H I J K L M N O P Q R S T U V W X Y Z Lowercase English alphabets a b c d e f g h i j k l m n o p q r s t u v w x y z Numerals 0 1 2 3 4 5 6 7 8 9 Special characters "#%&'()\*+,-./:;[¥]^\_|~ Blank characters (space) (tab) New line characters (return) (line feed)



#### **Reserved Words**

The following lists the reserved words of the AS308 system. The reserved words are not discriminated between uppercase and lowercase. Therefore, "abs", "aBS', "aBS

| Mnemonic<br>ABS<br>BAND<br>BMGT<br>BMNC<br>BNAND<br>BRK2<br>CMP<br>DIVX<br>FCLR<br>INDEXW | ADC<br>BCLR<br>BMGTU<br>BMNE<br>BNOR<br>BSET<br>CMPX<br>DSBB<br>FREIT<br>INDEXWD | ADCF<br>BITINDEX<br>BMLE<br>BMNO<br>BNOT<br>BTST<br>DADC<br>DSUB<br>FSET<br>INDEXWS | ADD<br>BMC<br>BMLEU<br>BMNZ<br>BNTST<br>BTSTC<br>DADD<br>ENTER<br>INC<br>INDEXL | ADDX<br>BMEQ<br>BMLT<br>BMO<br>BNXOR<br>BTSTS<br>DEC<br>EXITD<br>INDEXB<br>INDEXLD | ADJNZ<br>BMGE<br>BMLTU<br>BMPZ<br>BOR<br>BXOR<br>DIV<br>EXTS<br>INDEXBD<br>INDEXLS | AND<br>BMGEU<br>BMN<br>BMZ<br>BRK<br>CLIP<br>DIVU<br>EXTZ<br>INDEXBS<br>INT |
|-------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|
| INTO JC<br>JLE                                                                            | JEQ<br>JLEU                                                                      | JGE<br>JLT                                                                          | JGEU<br>JLTU                                                                    | JGT<br>JMP                                                                         | JGTU<br>JMPI                                                                       | JMPS                                                                        |
| JN<br>JSR                                                                                 | JNC<br>JSRI                                                                      | JNE<br>JSRS                                                                         | JNO<br>JZ                                                                       | JNZ<br>LDC                                                                         | JO<br>LDCTX                                                                        | JPZ<br>LDIPL                                                                |
| MAX<br>MOVLL<br>OR<br>PUSHM<br>SBB<br>SCGTU<br>SCNC<br>SHA<br>SSTR<br>SUBX                | MIN<br>MUL<br>POP<br>REIT<br>SBJNZ<br>SCLE<br>SCNE<br>SHL<br>STC<br>TST          | MOV<br>MULEX<br>POPC<br>RMPA<br>SCC<br>SCLEU<br>SCNO<br>SIN<br>STCTX<br>UND         | MOVA<br>MULU<br>POPM<br>ROLC<br>SCEQ<br>SCLT<br>SCNZ<br>SMOVB<br>STNZ<br>WAIT   | MOVHH<br>NEG<br>PUSH<br>RORC<br>SCGE<br>SCLTU<br>SCO<br>SMOVF<br>STZ<br>XCHG       | MOVHL<br>NOP<br>PUSHA<br>ROT<br>SCGEU<br>SCMPU<br>SCPZ<br>SMOVU<br>STZX<br>XOR     | MOVLH<br>NOT<br>PUSHC<br>RTS<br>SCGT<br>SCN<br>SCZ<br>SOUT<br>SUB           |
| Register/flag                                                                             | A 4                                                                              | Р                                                                                   | С                                                                               | D                                                                                  | DCT0                                                                               | DOT1                                                                        |
| A0<br>DMA0<br>DRC1<br>IPL<br>R1<br>S<br>VCT                                               | A1<br>DMA1<br>DRA0<br>ISP<br>R1H<br>SB<br>Z                                      | B<br>DMD0<br>DSA1<br>O<br>R1L<br>SP                                                 | DMD1<br>FB<br>PC<br>R2<br>SVF                                                   | D<br>DRA0<br>FLG<br>R0<br>R2R0<br>SVP                                              | DCTU<br>DRA1<br>I<br>R0H<br>R3<br>U                                                | DCT1<br>DRC0<br>INTB<br>R0L<br>R3R1<br>USP                                  |
| <b>Operators</b><br>SIZEOF                                                                | TOPOF                                                                            |                                                                                     |                                                                                 |                                                                                    |                                                                                    |                                                                             |
| System Label(a                                                                            | II names that                                                                    | begin with T                                                                        | Two Periods                                                                     | ; "")                                                                              |                                                                                    |                                                                             |



## **Description of Names**

| Any desired names can be used in the source program as defined.<br>Names can be divided into the following five types. Note that the AS308 system reserved words cannot be used in names. <sup>(Note)</sup> |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| (1)Label                                                                                                                                                                                                    |
| (2)Symbol                                                                                                                                                                                                   |
| (3)Bit symbol<br>(4)Location symbol                                                                                                                                                                         |
| (5)Macro name                                                                                                                                                                                               |

#### Rules for writing names

- (1) Names can be written using alphanumeric characters and "\_" (underscore). Each name must be within 255 characters in length.
- (2) Names are case-sensitive, so they are discriminated between uppercase and lowercase.
- (3) Numerals cannot be used at the beginning of a name.

Note: Program operation cannot be guaranteed if any reserved word is used.



## **Types of Names**

Table 3.2.1 shows the method for defining names.

#### Table 3.2.1 Types of Names Defined by User

| Label                                                                                                                                                                                                                                                                                                         | Symbol                                                                                                                                                                                                                                                       |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Function<br>Indicates a specific memory address.                                                                                                                                                                                                                                                              | Function<br>Indicates a constant value.                                                                                                                                                                                                                      |
| Definition method<br>Always add ":" (colon) at the end of each name.<br>There are two methods of definition.<br>1. Allocate an area with a directive command.<br>Example:<br>flag: .BLKB 1<br>work: .BLKB 1<br>2. Write a name at the beginning of a source line.<br>Example:<br>name1:<br>name:<br>sum_name: | Definition method<br>Use a directive command that defines a numeral.<br>Example:<br>value1 .EQU 1<br>value2 .EQU 2<br>Reference method<br>Write a symbol in the operand of an instruction.<br>Example:<br>MOV.W R0,value2+1<br>value3 .EQU value2+1          |
| Reference method<br>Write the name in the operand of an instruction.<br>Example:J<br>MP sym_name                                                                                                                                                                                                              |                                                                                                                                                                                                                                                              |
| Bit symbol                                                                                                                                                                                                                                                                                                    | Location symbol                                                                                                                                                                                                                                              |
| Function<br>Indicates a specific bit position in specific memory.<br>Definition method<br>Use a directive command that defines a bit symbol.<br>Example:<br>flag1 .BTEQU 1,flags<br>flag2 .BTEQU 2,flags<br>flag3 .BTEQU 20, flags<br>flags flag3 .BTEQU 20, flags<br>flags flag3 .BTEQU 20, flags            | Function<br>Indicates the current line of the source program.<br>Definition method<br>Unnecessary.<br>Reference method<br>Simply write a dollar mark (\$) in the operand to<br>indicate the address of the line where it is written.<br>Example:<br>JMP \$+5 |



## **Description of Operands**

For mnemonics and directive commands, write an operand to indicate the subject to be operated on by that instruction. Operands are classified into five types by the method of description. Some instructions do not have an operand. For details about use of operands in instructions and types of operands, refer to explanation of the method for writing each instruction.

#### • Numeric value

Numeric values can be written in decimal, hexadecimal, binary, and octal. Table 3.2.2 shows types of operands, description examples, and how to write the operand.

| Туре                      | Description<br>Example            | Method of Description                                                                                                                                                                                    |
|---------------------------|-----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Binary                    | 10010001B<br>10010001b            | Write 'B' or 'b' at the end of the operand.                                                                                                                                                              |
| Octal                     | 60702o<br>60702O                  | Write 'O' or 'o' at the end of the operand.                                                                                                                                                              |
| Decimal                   | 9423                              | Do not write anything at the end of the operand.                                                                                                                                                         |
| Hexadecimal               | 0A5FH<br>5FH<br>0a5fh<br>5fh      | Use numerals 0 to 9 and alphabets 'a' to 'f' or 'A' to 'F'<br>to write the operand and add 'H' or 'h' at the end.<br>However, if the operand value begins with an<br>alphabet, add '0' at the beginning. |
| Floating-<br>point number | 3.4E35<br>3.4E-35<br>5e20<br>5e20 | Write an exponent including the sign after 'E' or 'e' in the exponent part. For 3.4 x 10 <sup>35</sup> , write 3.4E35.                                                                                   |
| Name                      | loop                              | Write a label or symbol name directly as it is.                                                                                                                                                          |
| Expression                | 256/2<br>label/3                  | Use a numeric value, name, and operator in combination to write an expression.                                                                                                                           |
| Character<br>string       | "string"<br>'string'              | Enclose a character string with single or double quotations when writing it.                                                                                                                             |

 Table 3.2.2 Description of Operands

## • Floating-point number

Numeric values within the range shown below that are represented by floating-point numbers can be written in the operand of an instruction. The method for writing floating-point numbers and description examples are shown in Table 3.2.2 in the preceding page. Floating-point numbers can only be used in the operands of the directive commands ".DOUBLE" and ".FLOAT". Table 3.2.3 lists the range of values that can be written in each of these directive commands.

## Table 3.2.3 Description Range of Floating-point Numbers

| Directive Command     | Description Range                                                                 |
|-----------------------|-----------------------------------------------------------------------------------|
| FLOAT (32 bits long)  | 1.17549435 x 10 - <sup>38</sup> to 3.40282347 x 10 <sup>38</sup>                  |
| DOUBLE (64 bits long) | 2.2250738585072014 x 10 <sup>-308</sup> to 1.7976931348623157 x 10 <sup>308</sup> |

#### Name

Label and symbol names can be written in the operand of an instruction. The method for writing names and a description example are shown in Table 3.2.2 in the preceding page.

#### • Expression

An expression consisting of a combination of a numeric value, name, and operator can be written in the operand of an instruction. A combination of multiple operators can be used in an expression. When writing an expression as a symbol value, make sure that the value of the expression will be fixed when the program is assembled. The value that derives from calculation of an expression is within the range of -2,147,483,648 to 2,147,483,648. Floating-point numbers can be used in an expression. The method for writing expressions and description examples are shown in Table 3.2.2 in the preceding page.

## • Character string

A character string can be written in the operand of some directive commands. Use 7-bit ASCII code to write a character string. Enclose a character string with single or double quotations when writing it. The method for writing character strings and description examples are shown in Table 3.2.2 in the preceding page.

# RENESAS

## Operator

Table 3.2.4 lists the operators that can be written in the source programs for AS308.

#### Table 3.2.4 List of Operators

| Monadic op       | erators                  | Conditional operators |                                                    |
|------------------|--------------------------|-----------------------|----------------------------------------------------|
| +                | Positive value           | >                     | Left-side value is greater than right-side value   |
| -                | Negative value           | <                     | Right-side value is greater than left-side value   |
| ~                | NOT                      | >=                    | Left-side value is equal to or greater thanright-  |
| SIZEOF           | Section size (in bytes)  |                       | side value                                         |
| TOPOF            | Start address of section | <=                    | Right-side value is equal to or greater thanleft-  |
| Dyadic operators |                          |                       | side value                                         |
|                  |                          | ==                    | Left-side value and right-side value are equal     |
| +                | Add                      | !=                    | Left-side value and right-side value are not equal |
| -                | Subtract                 | Calculation p         | priority modifying operator                        |
| *                | Multiply                 | 0                     | A term enclosed with () is calculated before any   |
| /                | Divide                   | V                     | other term. If multiple terms in an expression are |
| %                | Remainder                |                       | enclosed with (), the leftmost term has priority.  |
| >>               | Shift bits right         |                       | Parentheses () can be nested.                      |
| <<               | Shift bits left          | aa                    |                                                    |
| &                | AND                      |                       |                                                    |
|                  | OR                       |                       |                                                    |
| ٨                | Exclusive OR             |                       |                                                    |

Note 1: For operators "SIZEOF" and "TOPOF," be sure to insert a space or tag between the operator and operand. Note 2: Conditional operators can only be written in the operands of directive commands ".IF" and ".ELIF".

## **Calculation Priority**

Calculation is performed in order of priorities of operators beginning with the highest priority operator. Table 3.2.5 lists the priorities of operators. If operators in an expression have the same priority, calculation is performed in order of positions from left to right. The priority of calculation can be changed by enclosing the desired term in an expression with ().

## Table 3.2.5 Calculation Priority

|                 | Priority<br>Level | Type of Operator                        | Content                    |
|-----------------|-------------------|-----------------------------------------|----------------------------|
| High<br>▲       | 1                 | Calculation priority modifying operator | (,)                        |
|                 | 2                 | Monadic operator 1                      | + ,  -, ~ , SIZEOF , TOPOF |
|                 | 3                 | Dyadic operator 1                       | *, / , %                   |
|                 | 4                 | Dyadic operator 2                       | +,-                        |
|                 | 5                 | Dyadic operator 3                       | >> , <<                    |
|                 | 6                 | Dyadic operator 4                       | &                          |
| Ì               | 7                 | Dyadic operator 5                       | ,^                         |
| <b>♦</b><br>Low | 8                 | Conditional operator                    | > , < , >= , <= , == , !=  |



#### **Description of Lines**

AS308 processes the source program one line at a time. Lines are separated by the new line character. A section from a character immediately after the new line character to the next new line character is assumed to be one line. The maximum number of characters that can be written in one line is 255. Lines are classified into five types by the content written in the line. Table 3.2.6 shows the method for writing each type of line.

- Directive command line
- Assembly source line
- Label definition line
- Comment line
- Blank line

#### Table 3.2.6 Types of Lines

| Directive Command Line                                                                                                                                                                                                                                                                                                                                                                                                                           | Assembly Source Line                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Function<br>This is the line in which as30 directive command<br>is written.<br>Description method<br>Only one directive command can be written in one<br>line. A comment can be written in the directive<br>command line.<br>Precautions<br>No directive command can be written along<br>with a mnemonic in the same line.<br>Example:<br>SECTION program,DATA<br>.ORG 00H<br>sym .EQU 0<br>work: .BLKB 1<br>.ALIGN<br>.PAGE "newpage"<br>.ALIGN | Function         This is the line in which a mnemonic is written.         Description method         A label name (at beginning) and a comment can be written in the assembly source line.         Precautions         Only one mnemonic can be written in one line.         No mnemonic can be written along with a directive command in the same line.         Example:         MOV.W       #0,R0         RTS         main:       MOV.W       #0,A0         RTS |  |
| Label Definition Line                                                                                                                                                                                                                                                                                                                                                                                                                            | Comment Line                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
| Function<br>This is the line in which only a label name is<br>written.<br>Description method<br>Always be sure to write a colon (:) immediately<br>following the label name.<br>Example:<br>Example:<br>start:<br>label: .BLKB 1<br>main: nop<br>loop:                                                                                                                                                                                           | Function<br>This is the line in which only a comment is<br>written.<br>Description method<br>Always be sure to write a semicolon (;) before<br>the comment.<br>Example:<br>; Comment line<br>MOV.W #0,A0<br>Blank Line<br>Function<br>This is the line in which no meaningful character is writted<br>Description method<br>Write only a space, tab, or new line code in this line.                                                                               |  |



## 3.2.2 Address Control

The following explains the AS308 system address control method.

The AS308 system does not take the RAM and ROM sizes into account as it controls memory addresses. Therefore, consider the actual address range in your application when writing the source programs and linking them.

## Method of Address Control

The AS308 system manages memory addresses in units of sections. The division of each section is defined as follows. Sections cannot be nested as they are defined.

#### **Division of section**

- (1) An interval from the line in which directive command ".SECTION" is written to the line in which the next directive command ".SECTION" is written
- (2) An interval from the line in which directive command ".SECTION" is written to the line in which directive command ".END" is written





## **Types of Sections**

A type can be set for sections in which units memory addresses are managed. The instructions that can be written in a section vary with each type of section.

#### Table 3.2.7 Types of Sections

| Туре                   | Content and Description Example                                                                                                                                                                                                                                                                                                |
|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CODE<br>(program area) | <ul> <li>This is an area where the program is written.</li> <li>All instructions except some directive commands that allocate memory can be written in this area.</li> <li>CODE-type sections must be specified in the absolute module that they be located in the ROM area. Example:</li> <li>SECTION program,CODE</li> </ul> |
| DATA                   | <ul> <li>This is an area where memory whose contents can be changed is located.</li> <li>Directive commands that allocate memory can be written in this area.</li> <li>DATA-type sections must be specified in the absolute module that they be located in the RAM area.</li></ul>                                             |
| (data area)            | Example: <li>SECTION mem,DATA</li>                                                                                                                                                                                                                                                                                             |
| ROMDTA                 | <ul> <li>This is an area where fixed data other than the program is written.</li> <li>ROMDATA-type sections must be specified in the absolute module that they be located in the ROM area.</li></ul>                                                                                                                           |
| (fixed data area)      | Example: <li>SECTION const,ROMDATA</li>                                                                                                                                                                                                                                                                                        |



## **Section Attribute**

A section in which units memory addresses are controlled is assigned its attribute when assembling the program.

#### Table 3.2.8 Section Attributes

| Attribute | Content and Description Example                                                                                                                                                                                                                                                                                                                                                                                                |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Relative  | <ul> <li>Addresses in the section become relocatable values when<br/>the program is assembled.</li> <li>The values of labels defined in the relative attribute section<br/>are relocatable.</li> </ul>                                                                                                                                                                                                                         |
| Absolute  | <ul> <li>Addresses in the section become absolute values when the program is assembled.</li> <li>The values of labels defined in the absolute attribute section are absolute.</li> <li>To make a section assume the absolute attribute, specify the address with directive command ".ORG" in the line next to one where directive command ".SECTION" is written.</li> <li>Example: .SECTION program,DATA .ORG 1000H</li> </ul> |

## Specifying an even address for the start address

For relative attribute sections, the start address of the section that is determined when linking can be set to be always located at an even address. If this adjustment is desired, specify "ALIGN" for the operand of the directive command ".SECTION."

Example:

.section program,CODE,ALIGN



## Address Control by AS308 System

The following shows how an assembly source program written in multiple files is converted into a single execution format file.

#### Address control by as308

- (1) For sections that will be assigned the absolute attribute, the assembler determines absolute addresses sequentially beginning with a specified address.
- (2) For sections that will be assigned the relative attribute, the assembler determines addresses sequentially for each section beginning with 0. The start address of all relative attribute sections are 0.

#### Address control by In308

- (1) Sections of the same name in all files are arranged in order of specified files.
- (2) The start address of sections thus rearranged is determined as specified by the command option (-order) of In308.
- (3) The start address of the first section is determined sequentially beginning with 0 unless otherwise specified.
- (4) Sections with different names are located at contiguous addresses in the order they are loaded into In308 unless otherwise specified.
- (5) When an attempt is made to locate an absolute attribute section after a relative attribute section of the same name, an error results.

Address values determined by as308





## Reading Include File into Source Program

The AS308 system allows the user to read an include file into any desired line of the source program. This helps to increase the program readability.

#### Reading include file into source program

Write the file name to be read into the source program in the operand of directive command ".INCLUDE". All contents of the include file are read into the source program at the position of this line.

Example:

.INCLUDE initial.inc

Source file (sample.a308)





## **Global and Local Address Control**

The following explains how the values of labels, symbols, and bit symbols are controlled by the AS308 system.

The AS308 system classifies labels, symbols, and bit symbols between global and local and between relocatable and absolute as it handles them. These classifications are defined below.

#### • Global

The labels and symbols specified with directive command ".GLB" are handled as global labels and global symbols, respectively.

The bit symbols specified with directive command ".BTGLB" are handle as global bit symbols. If a name defined in the source file is specified as global, it is made referencible from an external file.

If a name not defined in the source file is specified as global, it is made an external reference label, symbol, or bit symbol that references a name defined in an external file.

#### Local

All names are handled as local unless they are specified with directive command ".GLB" or ".BTGLB".

Local names can be referenced in only the same file where they are defined.

Local names are such that the same label name can be used in other files.

#### Relocatable

The values of local labels, symbols, and bit symbols within relative sections are made relocatable. The values of externally referenced global labels, symbols, and bit symbols are made relocatable.

#### • Absolute

The values of local labels, symbols, and bit symbols defined in an absolute attribute section are made absolute.

The labels, symbols, and bit symbols handled as absolute have their values determined by as308. The values of all other labels, symbols, and bit symbols are determined by In308<sup>(Note)</sup> when linking programs.

Figure 3.2.4 shows the relationship of various types of labels.

Note: A warning is output if linking resulted in any of these values exceeding the assembler-determined range in which branch instructions or addressing modes can be specified.







## 3.2.3 Directive Commands

In addition to the M16C/80 series machine language instructions, the directive commands of the AS308 system can be used in the source program. Following types of directive commands are available. This section explains how to use each type of directive command.

#### (1)Address control command

To direct address determination when assembling the program.

#### (2)Assemble control directive command

To direct execution of AS308.

#### (3)Link control directive command

To define information for controlling address relocation.

#### (4)List control directive command

To control the format of list files generated by AS308.

#### (5)Branch optimization control directive command

To direct selection of the optimum branch instruction to AS308.

#### (6)Conditional assemble control directive command

To choose a block for which code is generated according to preset conditions when assembling the program.

#### (7)Extended function directive command

To exercise other control than those described above.

#### (8)Directive commands output by cross tools

The directive commands output by the M16C/80-series tool software cannot be written in source programs by the user. If this precaution is neglected, program operation cannot be guaranteed.



## **Address Control**

| Command | Function                                                             | Usage and Description Example                                                                                                                                                                                                                                                                                                                   |
|---------|----------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| .ORG    | Declares an address.                                                 | Write this command immediately after<br>directive command ".SECTION". Unless this<br>command is found immediately after the<br>section directive command, the section is not<br>made a relative attribute section. This<br>command cannot be written in relative<br>attribute sections.<br>.ORG 0F0000H<br>.ORG offset<br>.ORG 0F0000H + offset |
| .BLKB   | Allocates a RAM area in units of 1 byte.                             | Write the number of areas to be allocated in the DATA section. When defining a label                                                                                                                                                                                                                                                            |
| .BLKW   | Allocates a RAM area in units of 2 bytes.                            | name, always be sure to add a colon (:).<br>Example:<br>.BLKB 1                                                                                                                                                                                                                                                                                 |
| .BLKA   | Allocates a RAM area in units of 3 bytes.                            | .BLKW number<br>.BLKA number+1                                                                                                                                                                                                                                                                                                                  |
| .BLKL   | Allocates a RAM area in units of 4 bytes.                            | label: .BLKL 1<br>label: .BLKF number<br>label: .BLKD number+1                                                                                                                                                                                                                                                                                  |
| .BLKF   | Allocates a RAM area for floating-point numbers in units of 4 bytes. |                                                                                                                                                                                                                                                                                                                                                 |
| .BLKD   | Allocates a RAM area in units of 8 bytes.                            |                                                                                                                                                                                                                                                                                                                                                 |
| .BYTE   | Stores data in the ROM area in length of 1 byte.                     | When writing multiple operands, separate them with a comma (,). When defining a label,                                                                                                                                                                                                                                                          |
| .WORD   | Stores data in the ROM area in length of 2 bytes.                    | always be sure to add a colon (:).<br>For .FLOAT and .DOUBLE, write a floating-<br>point number in the operand.                                                                                                                                                                                                                                 |
| .ADDR   | Stores data in the ROM area in length of 3 bytes.                    | Example:<br>.SECTION value,ROMDATA                                                                                                                                                                                                                                                                                                              |
| .LWORD  | Stores data in the ROM area in length of 4 bytes.                    | .BYTE 1<br>.BYTE 1,2,3,4,5<br>.WORD "da","ta"                                                                                                                                                                                                                                                                                                   |
| .FLOAT  | Stores a floating-point number in the ROM area in length of 4 bytes. | ADDR symbol<br>LWORD symbol+1<br>FLOAT 5E2                                                                                                                                                                                                                                                                                                      |
| .DOUBLE | Stores a floating-point number in the ROM area in length of 8 bytes. | constant .DOUBLE 5e2                                                                                                                                                                                                                                                                                                                            |
| .ALIGN  | Corrects odd addresses to even addresses.                            | This command can be written in the relative or absolute attribute section where address correction is specified when defining a section.                                                                                                                                                                                                        |
|         |                                                                      | Example:<br>.SECTION work,DATA,ALIGN<br>ram1: .BLKB 1<br>.ALIGN<br>ram2: .BLKW 2<br>.SECTION const,ROMDATA<br>.ORG 0F000H<br>data1: .BYTE 12H<br>.ALIGN<br>data 2: .WORD symbol<br>.END                                                                                                                                                         |



## **Assemble Control**

| Command        | Function                                        | Usage and Description Example                                                                                                                                                                                        |
|----------------|-------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| .EQU<br>.BTEQU | Defines a symbol.<br>Defines a bit symbol.      | Forward referenced symbol names cannot be<br>written. A symbol or expression can be written<br>in the operand. Symbols and bit symbols can<br>be specified as global.                                                |
|                |                                                 | Example:<br>symbol .EQU 1<br>symbol1.EQU symbol+symbol<br>bit0 .BTEQU 0,0<br>bit1 .BTEQU 1,symbol1                                                                                                                   |
| .END           | Declares the end of the assemble source.        | Write at least one instance of this command in<br>one assembly source file. For lines following<br>this directive command, as308 does not<br>perform code generation or any other<br>processing.<br>Example:<br>.END |
| .SB            | Assumes an SB register value.                   | Always be sure to set each register before<br>choosing the desired addressing mode.<br>Since register values are not set in the actual                                                                               |
| .SBSYM         | Chooses SB relative addressing.                 | register, write an instruction to set the register value immediately before or after this directive command.                                                                                                         |
| .SBBIT         | Chooses bit instruction SB relative addressing. | Example:<br>.SB 400H                                                                                                                                                                                                 |
| .FB            | Assumes an FB register value.                   | LDC #400H,SB<br>.SBSYM sym1,sym2                                                                                                                                                                                     |
| .FBSYM         | Chooses FB relative addressing.                 | .FB 500H<br>LCD #580H,FB<br>.FBSYM sym3,sym4                                                                                                                                                                         |
| .INCLUDE       | Reads a file into a specified position.         | Always be sure to write the extension for the file name in the operand. Directive command "FILE" or a character string including "@" can be written in the operand.                                                  |
|                |                                                 | Example:<br>.INCLUDE initial.a30<br>.INCLUDEFILE@.inc                                                                                                                                                                |



## Link Control

| Command | Function                                                                   | Usage and Description Example                                                                                                                                                                                                                                                                                                                   |
|---------|----------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SECTION | Defines a section name.                                                    | When specifying section type and ALIGN<br>simultaneously, separate them with a comma.<br>The section type that can be written here is<br>CODE, ROMDATA, or DATA. If section type<br>is omitted, CODE is assumed.<br>Example:<br>.SECTION program,CODE<br>NOP<br>.SECTION ram,DATA<br>.BLKB 10<br>.SECTION dname,ROMDATA<br>.BYTE "abcd"<br>.END |
| .GLB    | Specifies a global label.                                                  | When writing multiple symbol names in                                                                                                                                                                                                                                                                                                           |
| .BTGLB  | Specifies a global bit symbol.                                             | operand, separate them with a comma (,).<br>Example:<br>.GLB name1,name2,mane3<br>.BTGLB flag4<br>.SECTION program<br>MOV.W #0,name1<br>BCLR flag4                                                                                                                                                                                              |
| .VER    | Outputs a specified character string to a map file as version information. | Write operands within one line. This<br>command can be written only once in one<br>assembly source file.<br>Example:<br>.VER 'strings'<br>.VER "strings"                                                                                                                                                                                        |



## **List Control**

| Command | d Function Usage and Description Example                                            |                                                                                                                                                                                                                                                                                                                                                                   |
|---------|-------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| .LIST   | Controls line data output to a list file.                                           | Write 'OFF' in the operand to stop line output<br>or 'ON' to start line output. If this specification<br>is omitted, all lines are output to the list file.<br>Example:<br>.LIST OFF<br>MOV.B #0,R0L<br>MOV.B #0,R0L<br>.LIST ON                                                                                                                                  |
| .PAGE   | Breaks page at a specified position in a list file.                                 | Enclose the operand with single (') or double<br>(") quotations when writing it. The operand<br>can be omitted.<br>Example:<br>.PAGE<br>.PAGE<br>.PAGE "strings"<br>.PAGE 'strings'                                                                                                                                                                               |
| .FORM   | Specifies a number of columns and<br>number of lines in one page of a list<br>file. | This command can be written a number of<br>times in one assembly source file. Symbols<br>can be used to specify the number of columns<br>or lines. Forward referenced symbols cannot<br>be used, however. If this specification is<br>omitted, the list file is output with 140 columns<br>and 66 lines per page.Example:FORM20,80.FORM60.FORM,100.FORMline,culmn |

# **Branch Instruction Optimization Control**

| Command | Function                                                            | Usage and Description Example                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------|---------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| .OPTJ   | Controls optimization of branch<br>instruction and subroutine call. | Various items can be written in the operand here,<br>such as those for optimum control of a branch<br>instruction and selection of an unconditional branch<br>instruction or subroutine call instruction to be<br>excluded from optimization. These items can be<br>specified in any order and can be omitted. If<br>omitted, the initial value or previously specified<br>content is assumed for the jump distance.<br>Example:<br>Following combinations of operands can be written.<br>.OPTJ OFF<br>.OPTJ OFF<br>.OPTJ ON,JMPW<br>.OPTJ ON,JMPW<br>.OPTJ ON,JMPW,JSRW<br>.OPTJ ON,JMPW,JSRA<br>.OPTJ ON,JMPA,JSRW<br>.OPTJ ON,JMPA,JSRA<br>.OPTJ ON,JMPA,JSRA<br>.OPTJ ON,JMPA,JSRA<br>.OPTJ ON,JMPA,JSRA |



## **Extended Function Directive Commands**

| Command | Function                                                                        | Usage and Description Example                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------|---------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| .ASSERT | Outputs a specified character string to a file or standard error output device. | When outputting a character string enclosed<br>with double quotations to a file, specify the file<br>name following ">" or ">>". The bracket ">"<br>creates a new file, so a message is output to it.<br>If a file of the same name exists, a message is<br>overwritten in it. The bracket ">>" outputs a<br>message along with the contents of the file. If<br>the specified file does not exist, it creates a<br>new file. Directive command "FILE" can be<br>written in the file name.<br>Example:<br>ASSERTstring" > sample.dat<br>ASSERTstring" >FILE |
| ?       | Specifies and references a temporary label.                                     | Write "?:" in the line to be defined as a temporary label. To reference a temporary label that is defined immediately before, write "?-" in the instruction operand. To reference a temporary label that is defined immediately after, write "?+" in the instruction operand. Example:                                                                                                                                                                                                                                                                     |
| FILE    | Indicates source file name information.                                         | This command can be written in the operand of<br>directive command ".ASSERT" or ".INCLUDE".<br>If command option "-F" is specified, "FILE" is<br>fixed to the source file name that is specified in<br>the command line. If the option is omitted, the<br>indicated source file name is the file name<br>where "FILE" is written.<br>Example:<br>ASSERT "sample" >FILE<br>NCLUDEFILE@.inc<br>ASSERT "sample" >FILE@.mes                                                                                                                                    |
| @       | Concatenates character strings before and after @.                              | This command can be written a number of<br>times in one line. If the concatenated character<br>strings are going to be used as a name, do not<br>enter a space or tab before and after this<br>command.<br>Example:<br>.ASSERT "sample" >FILE@.dat<br>Following macro definition is also possible:<br>mov_nibble .MACRO p1,src,p2,dest<br>MOV@p1@p2 src,dest<br>.ENDM                                                                                                                                                                                      |



## **Conditional Assemble Directive Commands**

| Command | Function                                                                    | Usage and Description Example                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|---------|-----------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| .IF     | Indicates the beginning of conditional assemble.                            | Always be sure to write a conditional<br>expression in the operand.<br>Example:<br>.IF TYPE=0<br>.BYTE "Proto Type Mode"<br>.ELIF TYPE>0<br>.BYTE "Mass Production Mode"<br>.ELSE<br>.BYTE "Debug Mode"<br>.ENDIF<br>Rules for writing conditional expression:<br>The assembler does not check whether the<br>operation has resulted in an overflow or<br>underflow. Symbols cannot be forward<br>referenced (i.e., symbols defined after this<br>directive command are not referenced). If a<br>forward referenced or undefined symbol is<br>written, the assembler assumes value 0 for the<br>symbol as it evaluates the expression.<br>Typical description of conditional expression:<br>sym < 1<br>sym < 1 |
| .ELIF   | Indicates condition for conditional assemble.                               | sym+2 < data1<br>sym+2 < data1+2<br>'smp1' ==name<br>Always be sure to write a conditional<br>expression in the operand. This directive<br>command can be written a number of times in<br>one conditional assemble block.<br>Example:<br>Same as described above                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| .ELSE   | Indicates the beginning of a block to be assembled when condition is false. | This directive command can be written more<br>than once in the conditional assemble block.<br>This command does not have an operand.<br>Example:<br>Same as described above                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| .ENDIF  | Indicates the end of conditional assemble.                                  | This directive command must be written at least<br>once in the conditional assemble block.This<br>command does not have an operand.Example:<br>Same as described above                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |



## 3.2.4 Macro Functions

This section explains the macro functions that can be used in AS308. The following shows the macro functions available with AS308:

#### Macro function

A macro function can be used by defining it with macro directive commands ".MACRO" to ".ENDM" and calling the defined macro.

#### Repeat macro function

A repeat macro function can be used by writing macro directive commands ".MREPEAT" to ".ENDM".

Figure 3.2.5 shows the relationship between macro definition and macro call.

#### **Macro Definition**

To define a macro, use macro directive command ".MACRO" and define a set of instructions consisting of more than one line in one macro name. Use ".ENDM" to indicate the end of definition. The lines enclosed between ".MACRO" and ".ENDM" are called the macro body.

All instructions that can be written in the source program but a bit symbol can be used in the macro body. Macros can be nested in up to 65,535 levels including macro definitions and macro calls. Macro names and macro arguments are case-sensitive, so they are discriminated between uppercase and lowercase letters.

## Macro Call

The contents of the macro body defined as a macro can be called into a line by writing the macro name defined with directive command ".MACRO" in that line. Macro names cannot be referenced externally. When calling the same macro from multiple files, define a macro in an include file and include that file to call the macro.



| Exa  | mple of  | source program  | [                              | Dummy argume                                     | nt     |    |                                              |
|------|----------|-----------------|--------------------------------|--------------------------------------------------|--------|----|----------------------------------------------|
|      |          |                 | $\gamma$                       |                                                  |        |    |                                              |
|      | mac      | .MACRO<br>.IF   | .IF                            | p1,p2,p3<br>'ARA == 3<br>'p1' == 'byte'<br>MOV.B | #p2,p3 | +• | Macro<br>definition part                     |
|      |          | .ELIF           | .ELSE<br>.ENDIF<br>MACP<br>.IF | MOV.W<br>'ARA == 2<br>'p1' == 'byte'             | #p2,p3 |    |                                              |
|      |          |                 | .IF                            | MOV.B                                            | p2,R0L |    |                                              |
|      |          | .ELSE           | .ENDIF<br>MOV.W                |                                                  | p2,R0  |    |                                              |
|      |          | .ENDIF<br>.ENDM |                                |                                                  |        |    |                                              |
|      | main     | .SECTION        | progran                        | Actual argur                                     | ment   |    |                                              |
|      | :mac     |                 | word,10                        | ),r0                                             |        | ►  | Macro call                                   |
|      | .END     |                 |                                |                                                  |        |    |                                              |
| Afte | r expans | sion            |                                |                                                  |        |    |                                              |
|      | main:    | .SECTION        | progran                        | n                                                |        |    |                                              |
|      |          | .IF             | 3 == 3<br>.ELSE<br>.ENDIF      | MOV.W                                            | #10,R0 |    | <ul> <li>Macro<br/>expansion part</li> </ul> |
|      |          | .ENDIF          | LINDI                          |                                                  |        |    |                                              |
|      |          | .END            |                                |                                                  |        | レ  |                                              |

Figure 3.2.5 Example 1 of macro definition and macro call

## Macro Local

Macro local labels declared with directive command ".LOCAL" can be used in only the macro definition. Labels declared to be macro local are such that the same label can be written anywhere outside the macro. Figure 3.2.6 shows a description example. In this example, m1 is the macro local label.

| name | .MACRO<br>.LOCLA | source,dest,top<br>m1 |   |
|------|------------------|-----------------------|---|
| m1:  |                  |                       |   |
|      | nop<br>jmp       | m1                    |   |
|      | .ENDM            | <i></i>               | ļ |
|      |                  |                       |   |





## **Repeat Macro Function**

The macro body enclosed with macro directive commands ".MREPEAT" and ".ENDM" is expanded into a specified line repeatedly as many times as specified. Macro call of a repeat macro is not available.

Figure 3.2.7 shows the relationship between macro definition and macro call of a repeat macro.

| rep      | .MACRO                       | num                      | <b>,</b> | Macro           |
|----------|------------------------------|--------------------------|----------|-----------------|
|          | .MREPE                       |                          |          | definition part |
|          |                              | .IF num > 49             |          |                 |
|          |                              | .EXITM<br>.ENDIF         |          |                 |
|          | MOV.B                        | #0,mem +MACREP           |          |                 |
|          | nop                          | -,                       |          |                 |
|          | .ENDR                        |                          |          |                 |
|          | .ENDM                        |                          |          |                 |
|          | .SECTION                     | program                  |          |                 |
| main:    | .02011011                    |                          |          |                 |
|          |                              | Actual argument          |          |                 |
|          | rep                          | 5                        |          | Macro call      |
|          | .END                         |                          |          |                 |
|          |                              |                          | r        |                 |
|          |                              |                          |          |                 |
| r expans | sion                         |                          |          |                 |
|          | .SECTION                     | program                  |          |                 |
| •        |                              |                          |          | Macro           |
| main:    |                              |                          |          |                 |
|          | MOV.B                        | #0,mem + 1               |          |                 |
|          | nop                          |                          | +        | expansion part  |
|          | nop<br>MOV.B                 | #0,mem + 1<br>#0,mem + 2 |          |                 |
|          | nop<br>MOV.B<br>nop          | #0,mem + 2               |          |                 |
|          | nop<br>MOV.B                 |                          | +        |                 |
|          | nop<br>MOV.B<br>nop<br>MOV.B | #0,mem + 2               |          |                 |





## Macro Directive Commands

There are following types of macro commands available with AS308:

• Macro directive commands

These commands indicate the beginning, end, or suspension of a macro body and declare a local label in the macro.

- **Macro symbols** These symbols are written as terms of an expression in macro description.
- Character string functions

These functions show information on a character string.

## **Macro Directive Commands**

| Command  | Function                                                                    | Usage and Description Example                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------|-----------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| .MACRO   | Defines a macro name and<br>indicates the beginning of macro<br>definition. | Always be sure to write a conditional expression<br>in the operand. Up to 80 dummy arguments can<br>be written. Do not enclose a dummy argument<br>with double quotations.<br><description format=""><br/>Macro definition<br/>(macro name) .MACRO [(dummy argument)<br/>[,(dummy argument)]]<br/>Macro call<br/>(macro name) [(actual argument)[,(actual<br/>argument)]]<br/><description example=""><br/>Refer to Figure 3.2.5.</description></description> |
| .ENDM    | Indicates the end of macro definition.                                      | Write this command in relation to ".MACRO".<br><description example=""><br/>Refer to Figure 3.2.5.</description>                                                                                                                                                                                                                                                                                                                                              |
| .LOCAL   | Declares that the label shown in the operand is a macro local label.        | Write this command within the macro body.<br>Multiple labels can be written by separating<br>operands with a comma. The maximum number<br>of labels that can be written in this way is 100.<br><description example=""><br/>Refer to Figure 3.2.6.</description>                                                                                                                                                                                              |
| .EXITM   | Forcibly terminates expansion of a macro body.                              | Write this command within the body of macro<br>definition.<br><description example=""><br/>Refer to Figure 3.2.7.</description>                                                                                                                                                                                                                                                                                                                               |
| .MREPEAT | Indicates the beginning of repeat macro definition.                         | The maximum number of repetitions is 65,535.<br><description example=""><br/>Refer to Figure 3.2.7.</description>                                                                                                                                                                                                                                                                                                                                             |
| .ENDR    | Indicates the end of repeat macro definition.                               | Write this command in relation to ".MREPEAT".<br><description example=""><br/>Refer to Figure 3.2.7.</description>                                                                                                                                                                                                                                                                                                                                            |



## Macro Symbol

| Command | Function                                                             | Usage and Description Example                                                                                                                                                                                                                                                                                                                                    |
|---------|----------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MACPARA | Indicates the number of actual arguments given when calling a macro. | This symbol can be written in the body of<br>macro definition as a term of an expression. If<br>written outside the macro body, value 0 is<br>assumed.<br><description example=""><br/>Refer to Figure 3.2.5.</description>                                                                                                                                      |
| MACREP  | Indicates the number of times a repeat macro is expanded.            | This symbol can be written in the body of macro definition as a term of an expression. It can also be written as an operand of conditional assemble. The value increments from 1 to 2, 3, and so on each time the macro is repeated. If written outside the macro body, value 0 is assumed.<br><description example=""><br/>Refer to Figure 3.2.7.</description> |

# **Character String Function**

| Command | Function                                                                                                      | Usage and Description Example                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------|---------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| .LEN    | Indicates the length of a character string written in operand.                                                | Always be sure to enclose the operand with<br>brackets { } and the character string with<br>quotations. Character strings can be written<br>using 7-bit ASCII code characters. This<br>function can be written as a term of an<br>expression.<br><description format=""><br/>.LEN {"(string)"}<br/>.LEN {"(string)"}<br/><description example=""><br/>Refer to Figure 3.2.8.</description></description>                                                                                                                                                                                     |
| .INSTR  | Indicates the start position of a<br>search character string in<br>character strings specified in<br>operand. | Always be sure to enclose the operand with<br>brackets { } and the character string with<br>quotations. Character strings can be written<br>using 7-bit ASCII code characters. If the<br>search start position = 1, it means the<br>beginning of a character string.<br><description format=""><br/>.INSTR {"(string)","(search character string)",<br/>(search start position)}<br/>.INSTR {'(string)','(search character string)',<br/>(search start position)}<br/>.INSTR {'(string)','(search character string)',<br/>(search start position)}<br/>.Refer to Figure 3.2.9.</description> |
| .SUBSTR | Extracts a specified number of<br>characters from the character<br>string position specified in<br>operand.   | Always be sure to enclose the operand with<br>brackets { } and the character string with<br>quotations. Character strings can be written<br>using 7-bit ASCII code characters. If the<br>extraction start position = 1, it means the<br>beginning of a character string.<br><description format=""><br/>.SUBSTR {"(string)",(start position),(number<br/>of characters)}<br/>.SUBSTR {'(string)',(start position),(number<br/>of characters)}<br/><description example=""><br/>Refer to Figure 3.2.10.</description></description>                                                           |



## Example of .LEN Statement

In the example of Figure 3.2.8, the length of a specified character string is "13" for "Printout\_data" and "6" for "Sample".

| oufset .MAC<br>ouffer@f1:<br>.ENDI | .BLKB          | f1,f2<br>.LEN{'f2'}         | + | Macro<br>definition |
|------------------------------------|----------------|-----------------------------|---|---------------------|
| bufse<br>bufse                     |                | 1,Printout_data<br>2,Sample |   | → Macro call        |
| expansion                          |                |                             |   |                     |
| ouffer1<br>ouffer2                 | .BLKB<br>.BLKB |                             |   |                     |

## Example of .INSTR Statement

In the example of Figure 3.2.9, the position (7) of character string "se" from the beginning x (top) of a specified character string (japanese) is extracted.

| top<br>point_set<br>point<br>.EN | .EQU<br>.MACRO<br>.EQU<br>NDM | 1<br>source,dest,top<br>.INSTR{'source','dest',top} | t | Macro<br>definition |  |
|----------------------------------|-------------------------------|-----------------------------------------------------|---|---------------------|--|
| poi                              | int_set japa                  | nese,se,1                                           |   | Macro call          |  |
|                                  |                               |                                                     |   |                     |  |
| acro expansio                    | n                             |                                                     |   |                     |  |



## Example of .SUBSTR Statement

In the example of Figure 3.2.10, the length of a character string given as the macro's actual argument is given to the operand of ".MREPEAT". Each time the ".BYTE" line is executed, "..MACREP" is increased from 1 to 2, 3, 4, and so on. Consequently, characters are passed one character at a time from the character string given as the actual macro argument to the operand of ".BYTE" sequentially beginning with the first character.



## 3.2.5 Differences with M16C/60

AS308 (M16C/80) has new addressing modes, instruction sets, and assemble options that have been added or changed from AS30 (M16C/60). But there are some addressing modes, instruction sets, and assemble options that are removed and not included in AS308. This section describes those that have been removed or changed.

## Changed addressing modes

As the memory space in M16C/80 has been expanded from 1M to 16M, the address ranges that can be accessed in all addressing modes, such as general instruction addressing and bit instruction addressing, have been expanded. Namely, locations following address 100000H can now be accessed.

Therefore, some addressing modes have become unusable in M16C/80, as described below.

(1)Following modes of specific instruction addressing have been removed:

(a) 20-bit absolute

- (b)Address register relative with 20-bit displacement attached
- (c)32-bit register direct
- (d)32-bit address register indirect

\* In M16C/80, general instruction addressing can be used for all of the above.

#### (2) Following modes of bit instruction addressing have been removed:

(a)Register direct

bit, R2

bit, R3

bit, A0

bit, A1

For register bit manipulation in M16C/80, bits 0 to 7 only can be specified.

Register direct in M16C/60 R (bits 0 to 15) bit, R0 bit, R1

Register direct in M16C/80 (bits 0 to 7) bit, R0L bit, R0H bit, R1L bit, R1H bit, A0(Only 8 low-order bits can be specified)

bit, A1(Only 8 low-order bits can be specified)



## **Removed instruction sets**

Following instructions have been removed and are not included in M16C/80: (1)LDE instruction (2)STE instruction (3)LDINTB (LDC macro) instruction

\* Because the memory space in M16C/80 has been expanded to 16M and because locations following address 100000H can also be accessed by general instruction addressing, LDE and STE instructions have been removed.

## Compatibility with M16C/60 instructions (1)

In some instructions of the M16C/80, src and dest that can be selected by each instruction (i.e., usable operands) are different from M16C/60.

AS308 supports "-mode60" as a command option necessary to assemble programs developed by AS30 (M16C/60 series). The following shows how instructions are processed by AS308 when this option is added.

- (1)The format specifier written in MOV, CMP, ADD, SUB, AND, OR, NOT, PUSH, or POP instruction is ignored.
- (2)The addressing mode specifier of JMPI and JSRI instructions are ignored.
- (3)When adding to the stack pointer (SP) in ADD instruction, the size specifier ".L" is assumed.
- (4)The LDINTB instruction is replaced with the LDC instruction when processing the instruction. Refer to Table 3.2.9.
- (5)The operands of STZ, STNZ, and STZX instructions are processed in byte size.
- (6)The LDE and STE instructions are replaced with the MOV instruction when processing the instruction. Refer to Table 3.2.9.
- (7)The 1-bit manipulate instruction is replaced with the corresponding AS308 (M16C/80) instruction when processing the instruction. Refer to Table 3.2.9
- (8) The bit manipulate instructions BCLR, BAND, BOR, BXOR, BNOT, BNAND, BNOR, BNXOR, BTST, BNTST, BTSTC, BTSTS, and BMcnd also are replaced in the same way as for the BSET instruction shown in the replacement instruction list.
# List of instructions replaced by the "-mode60" option

# Table 3.2.9 Replacement Instruction List

| AS30                       | source description format                               | Results                                | when replaced in AS308         |  |  |
|----------------------------|---------------------------------------------------------|----------------------------------------|--------------------------------|--|--|
| LDINTB #imm20              |                                                         | LDC #imm2                              | LDC #imm24,INTB                |  |  |
| LDE.B/W                    | dsp:20, dest                                            | MOV.B/W                                | abs, dest                      |  |  |
| LDE.B/W                    | dsp:20[A0], dest                                        | MOV.B/W                                | dsp[A0], dest                  |  |  |
| STE.B/W                    | src, abs:20                                             | MOV.B/W                                | src, abs                       |  |  |
| STE.B/W                    | src ,dsp:20[A0]                                         | MOV.B/W                                | src, desp[A0]                  |  |  |
| BSET:G                     | bit, R0                                                 | BSET<br>BSET                           | bit, R0L<br>bit, R0H           |  |  |
| BSET:G                     | bit, R1                                                 | BSET<br>BSET                           | bit, R1L<br>bit, R1H           |  |  |
| BSET:G                     | bit, A0                                                 | Can be assembled for bit positions 0 t |                                |  |  |
| BSET:G                     | bit, A1                                                 | Can be assem                           | nbled for bit positions 0 to 7 |  |  |
| BSET:G                     | bit, [A0]                                               | BITINDEX.B<br>BSET                     | [A0]<br>0, 0                   |  |  |
| BSET:G                     | bit, [A1]                                               | BITINDEX.B<br>BSET                     | [A1]<br>0, 0                   |  |  |
| BSET:G                     | bit, base:8[A0]                                         | BITINDEX.B<br>BSET                     | [A0]<br>0, base                |  |  |
| BSET:G                     | bit, base:16[A0]                                        | BITINDEX.B<br>BSET                     | [A0]<br>0, base                |  |  |
| BSET:G                     | bit, base:8[A1]                                         | BITINDEX.B<br>BSET                     | [A1]<br>0, base                |  |  |
| BSET:G                     | bit, base:16[A1]                                        | BITINDEX.B<br>BSET                     | [A1]<br>0, base                |  |  |
| BSET:G<br>BSET:G<br>BSET:G | bit, base:8[SB]<br>bit, base:11[SB]<br>bit, base:16[SB] | BSET                                   | bit, base[SB]                  |  |  |
| BSET:G                     | bit, base:8[FB]                                         | BSET                                   | bit, base[FB]                  |  |  |
| BSET:G                     | bit, base:16                                            | BSET                                   | bit, base                      |  |  |



#### Compatibility with M16C/60 instructions (2)

The following instructions cannot be replaced with M16C/80 equivalents even by using the command option "-mode60." For these instructions, compatibility can be maintained by changing the source program directly.

| (1)MOVA            | src, R0                                                                                                                                                    |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| (2)MOVA            | src, R1                                                                                                                                                    |
| (3)MOVA            | src, R2                                                                                                                                                    |
| (4)MOVA            | src,R3                                                                                                                                                     |
| (5)JMPI.A          | src = dsp[A0],dsp[A1],dsp[SB],dsp[FB],abs16<br>A1A0                                                                                                        |
| (6)JSRI.A          | A1A0                                                                                                                                                       |
| (7)PUSHC           | INTBL                                                                                                                                                      |
| (8)PUSHC           | INTBH                                                                                                                                                      |
| (9)POPC            | INTBL                                                                                                                                                      |
| (10)POPC           | INTBH                                                                                                                                                      |
| (11)MUL.W          | generic, A0                                                                                                                                                |
| (12)MULU.W         | generic, A0                                                                                                                                                |
|                    | generic = R0, R1, R2, R3, A0, A1, [A0], [A1],<br>dsp[SB], dsp[FB], dsp[A0], dsp[A1], abs16                                                                 |
| (13)LDC<br>(14)STC |                                                                                                                                                            |
| (15)LDE.B/W        | [A1A0], generic                                                                                                                                            |
| (16)STE.B/W        | generic, [A1A0]                                                                                                                                            |
|                    | generic = R0L/R0, R0H/R1, R1L/R2, R1H/R3, A0, A1, [A0], [A1],<br>dsp[SB], dsp[FB], dsp[A0], dsp[A1], abs16                                                 |
| (17)BSET:G         | bit, R2                                                                                                                                                    |
| (18)BSET:G         | bit, R3                                                                                                                                                    |
| · · ·              | te instructions BCLR, BAND, BOR, BXOR, BNOT, BNAND, BNOR, BNXOR,<br>ST, BTSTC, BTSTS, and BMcnd which are written in the same way as "BSET:G<br>struction. |



#### **Removed assemble options**

AS308 has had the following options removed.

- (1)-M60, -M61, -M62, -M62E (options for identification of M16C groups)
- (2)-A (option for operand evaluation in mnemonic)
- (3)-P (option for structured description instructions)

#### **Option for structured description**

Although AS308 does not support the structured description of instructions, it supports "-mode60p" as an option necessary to assemble programs developed by AS30 (M16C/60) using structured description.

(1)-mode60p

After starting the structured description preprocessor (pre30) that accompanies the structured description of AS30, the command option "-mode60" is processed.<sup>(note)</sup>

Note: Because AS308 does not support structured description, not all structured sources can be processed by AS308. Therefore, structured description that expands into nonexistent mnemonics of AS308 or mnemonics that behave differently in AS308 cannot be handled by adding this option. In such a case, the assembly source must be changed by the user.



# **Chapter 4**

# **Programming Style**

- 4.1 Hardware Definition
- 4.2 Initial Setting of CPU
- 4.3 Setting when using Interrupts
- 4.4 Dividing Source File
- 4.5 A Little Tips...(Programing Technique)
- 4.6 Standard processing program



# 4.1 Hardware Definition

This section explains how to define an SFR area and create an include file, how to allocate RAM data and ROM data areas, and how to define a section.

## 4.1.1 Defining SFR Area

It should prove convenient to create the SFR area's definition part in an include file. There are two methods for defining the SFR area as described below.

#### **Definition by .EQU**

|       |                | Define the address at which processor mode register 0 is placed.<br>In the following lines, define the addresses of other registers. |  |
|-------|----------------|--------------------------------------------------------------------------------------------------------------------------------------|--|
| M3    | 0800 SFR Defin | ition File                                                                                                                           |  |
| PM0   | .EQU           | 0004H ]; Processor mode register 0                                                                                                   |  |
| PM1   | .EQU           | 0005H ; Processor mode register 1                                                                                                    |  |
| CM0   | .EQU           | 0006H ; System clock control register 0                                                                                              |  |
| CM1   | .EQU           | 0007H ; System clock control register 1                                                                                              |  |
| WCR   | .EQU           | 0008H ; Wait control register                                                                                                        |  |
| AIER  | .EQU           | 0009H ; Address match interrupt enable register                                                                                      |  |
| PRCR  | .EQU           | 000AH ; Protect register                                                                                                             |  |
| DS    | .EQU           | 000BH ; External data bus widthcontrol register                                                                                      |  |
| MCD   | .EQU           | 000CH ; Main clock division register Define the start address of a register                                                          |  |
|       |                | that consists of more than 2 bytes.                                                                                                  |  |
| WDTS  | .EQU           | 000EH ; Watchdog timer start register                                                                                                |  |
| WDC   | .EQU           | 000FH ; Watchdog timer control register                                                                                              |  |
| RMAD0 | .EQU           | 0010H , Address match instruction register 0                                                                                         |  |
| RMAD1 | .EQU           | 0014H ; Address match instruction register 1                                                                                         |  |
| RMAD2 | .EQU           | 0018H ; Address match instruction register 2                                                                                         |  |
| RMAD3 | .EQU           | 001CH ; Address match instruction register 3                                                                                         |  |
| EIAD  | .EQU           | 0020H ; Emulator interrupt vector table register                                                                                     |  |
| EITD  | .EQU           | 0023H ; Emulator interrupt detect register                                                                                           |  |
| EPRR  | .EQU           | 0024H ; Emulator protect register                                                                                                    |  |
| ROA   | .EQU           | 0030H ; ROM areaset register                                                                                                         |  |



# Definition by .BLKB

| SECTION       SFR,DATA       Specify an absolute address according to the address according to the address at which processor mode register 0 is placed.         PM0       .BLKB 1       ; Processor mode register 0         PM1       .BLKB 1       ; Processor mode register 1         CM0       .BLKB 1       ; System clock control register 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |    |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| PM1 .BLKB 1 ; Processor mode register 1 mode register 0 is placed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |    |
| CM1       .BLKB 1       ; System clock control register 1         WCR       .BLKB 1       ; Wait control register         AIER       .BLKB 1       ; Address match interrupt enable register         PRCR       .BLKB 1       ; Protect register         DS       .BLKB 1       ; External data bus widthcontrol register         MCD       .BLKB 1       ; Main clock division register         ;       .ORG       00000EH         ;       .ORG       00000EH         ;       .ORG       00000EH         ;       .Watchdog timer start register       Note that unless 0000EH is specified for the absolute address here, the area for the watchdog timer start register will be set at 0000BH, a location next to the protect register.         WDC:       .BLKB 1       ; Watchdog timer control register         RMAD0:       .BLKB 1       ; Address match instruction register 0         .BLKB 1       ; Address match instruction register 1       Allocate areas even for locations | 11 |
| RMAD2:       .BLKB 1       ; Address match instruction       .Allocate areas even for locations where nothing is placed.         .BLKB 1       .BLKB 1       .BLKB 1       .BLKB 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |    |
| ;<br>.ORG 000020H<br>EIAD .BLKA 1 ; Emulator interrupt vector table register<br>EITD .BLKB 1 ; Emulator interrupt detect register<br>EPRR .BLKB 1 ; Emulator protect register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |    |
| ORG000030HROA.BLKB 1; ROM area set registerDBA.BLKB 1; Debug monitor area set registerEXA.BLKB 1; Expansion area set register 0EXA.BLKB 1; Expansion area set register 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |    |



## **Creating Include File**

When creating the source program in separate files, create an include file for SFR definition and other parts that are used by multiple files. Normally add an extension ".INC" for the include file.

#### Precautions on creating include file

#### (1) When using ".EQU" in include file

Directive command ".EQU" defines values for symbols. It can also be used to define addresses as in SFR definition. However, since this is not a command to allocate memory areas, make sure that the addresses defined with it will not overlap. The include file created using ".EQU" can be used in multiple files by reading it in.

#### (2) When using ".ORG" in include file

If an include file created using ".ORG" is read into multiple files, a link error will result. This is because the include file contains the absolute addresses specified by ".ORG". Consequently, the defined addresses overlap with each other.

#### (3) When using ".BLKB", ".BLKW", and ".BLKA" in include file

Directive commands ".BLKB", ".BLKW", and ".BLKA" are used to allocate memory areas. If an include file created using these directive commands is read into multiple files, areas will be allocated separately in each file. Although no error may occur when using symbols in the include file locally, care must be taken when using them globally because it could result in duplicate definitions.

If use of a common area in multiple files is desired, define the area-allocated part in a shared definition file and link it as one of the source files. Then define the symbol's global specification part in an include file.

#### **Reading Include File into Source File**

Use directive command ".INCLUDE" to read an include file into the source file. Specify the file name to be read in with a full name.

Example:

When reading an include file "M30800.INC" that contains a definition of the SFR area .INCLUDE M30800.INC



# 4.1.2 Allocating RAM Data Area

Use the following directive commands to allocate a RAM area:

.BLKB ..... Allocates a 1-byte area (integer) .BLKW .... Allocates a 2-byte area (integer) .BLKA ..... Allocates a 3-byte area (integer) .BLKL ..... Allocates a 4-byte area (integer) .BLKF ..... Allocates a 4-byte area (floating-point) .BLKD ..... Allocates a 8-byte area (floating-point)

#### **Example for Setting Up Work Area**





# 4.1.3 Allocating ROM Data Area

Use the directive commands listed below to set fixed data in ROM. For a description example, refer to Section 4.1.5, "Sample Program List 1 (Initial Setting 1)".

.BYTE ...... Sets 1-byte data (integer) .WORD ..... Sets 2-byte data (integer) .ADDR ..... Sets 3-byte data (integer) .LWORD .... Sets 4-byte data (integer) .FLOAT ..... Sets 4-byte data (floating-point) .DOUBLE ... Sets 8-byte data (floating-point)

## **Retrieving Table Data**

Figure 4.1.4 shows an example of a data table. Figure 4.1.5 shows a method for accessing this table by using address register relative addressing.



## Figure 4.1.4 Example for setting a data table



#### Figure 4.1.5 Example for retrieving data table



## 4.1.4 Defining a Section

Directive command ".SECTION" declares a section in which a program part from the line where this directive command is written to the next ".SECTION" is allocated.

#### **Description Format of Section Definition**

.SECTION section name [,(section type), ALIGN] Specification in [] can be omitted.

A range of statements from one directive command ".SECTION" to a position before the line where the next ".SECTION" or directive command ".END" is written is defined as a section. Any desired section name can be set. Furthermore, one of section types (DATA, CODE, or ROMDATA) can be set for each section. Note that the instructions which can be written in the section vary with this section type. For details, refer to AS308 User's Manual.

If ".ALIGN" is specified for a section, the linker (In308) locates the beginning of the section at an even address.

#### **Example for Setting Up Sections**





#### **Section Attributes**

Each section is assigned an attribute when assembling the program. There are two attributes: relative and absolute.

#### (1) Relative attribute

- Location of each section can be specified when linking source files. (Relocatable)
- Addresses in the section are made relocatable values when assembling the program.
- The values of labels defined in this type of section become relocatable.

#### (2) Absolute attribute

- A section is assigned an absolute attribute and handled as such by specifying addresses with ".ORG" immediately after directive command ".SECTION".
- Addresses in the section are made relocatable values when assembling the program.
- The values of labels defined in this type of section become absolute.



# 4.1.5 Sample Program List 1 (Initial Setting 1)

| INCLUDE      | M30800.INC                      |                   | ude file into source file.                                            |
|--------------|---------------------------------|-------------------|-----------------------------------------------------------------------|
| INCLODE      | 10130000.1140                   | 1                 |                                                                       |
| ******       | Symbol definiti                 | on *************  | **************                                                        |
| M TOP        | .EQU 0004                       | IOOH              | :Start address of RAM                                                 |
| M END        |                                 | BFFH              | ;End address of RAM                                                   |
| M_TOP        | .EQU 0FE                        | D000H             | Start address of ROM                                                  |
| ED VECT TOP  | .EQU 0FFF                       | FDCH              | Start address of fixed vector                                         |
| BASE         | .EQU 0004                       | 100H              | Base address of SB relative addressing                                |
| BASE         | .EQU 0005                       |                   | ;Base address of FB relative addressing                               |
| ACK_SIZE     | .EQU 300H                       |                   | ;Interrupt stack area size                                            |
|              | A.II                            |                   | ******                                                                |
| /            | Allocation of wo                | rk RAM area **    |                                                                       |
| .SECTION     | WORK,DAT                        | Matched           | to hardware RAM area.                                                 |
| .ORG         | RAM_TOP                         |                   |                                                                       |
| ſ            |                                 | ) at the end of a | a label name.                                                         |
| RKRAM_TOP:   |                                 |                   |                                                                       |
| r:           | .BLKB                           | 1                 | ;Allocates a 1-byte area.                                             |
| rt:          | .BLKW                           | 1                 | ;Allocates a 2-byte area.                                             |
| r:           | .BLKA                           | 1                 | ;Allocates a 3-byte area.                                             |
|              | .BLKL                           | 1                 | ;Allocates a 4-byte area.                                             |
| RKRAM_END:   |                                 |                   |                                                                       |
| *****        | Definition of bit               | svmbo ********    | ******                                                                |
| Do not add   | ":" (colon) for a               | bit symbol.       |                                                                       |
| r_b0         | .BTEQU                          | 0,char            | ; Bit 0 of char                                                       |
| rt_b1        | .BTEQU                          | 1,short           | ; Bit 1 of short                                                      |
| r_b2         | .BTEQU                          | 2,addr            | ; Bit 2 of addr                                                       |
| <u>j_</u> b3 | .BTEQU                          | 3,long            | ; Bit 3 of long                                                       |
| <b>م</b>     | rogrom oroo **                  | *****             | *****                                                                 |
|              | rogram area **<br>artup ======= |                   |                                                                       |
| •            |                                 |                   | Must be metched to berdware and                                       |
| .SECTION     | PROGRAM,CODE                    |                   | Must be matched to hardware and the contents selected in programming. |
| .ORG         | ROM_TOP                         |                   | The contents selected in programming.                                 |
| ART:         |                                 |                   | · Sote initial value in stack pointer/ISP)                            |
|              | #RAM_END-                       | T1,10F            | ; Sets initial value in stack pointer(ISP).                           |
| MOV.         | B #03F                          | I,PRCR            | ; Removes protection.                                                 |
| MOV.         |                                 | 3H,PM0            | ; Sets processor mode register 0 and 1.                               |
| MOV.         |                                 | )8H,CM0           | ; Sets system clock control register.                                 |
| MOV.         | B #12H                          | I,MCD             | ; Sets main clock division register.                                  |
| MOV.         |                                 | RCR               | ; Protects all registers.                                             |



|                                       | a                                                          | ust be matched to hardware<br>nd the contents selected in<br>rogramming.                                                                                                                                                                                                                                                                     |
|---------------------------------------|------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                       | MOV.W<br>MOV.B<br>MOV.W<br>MOV.B<br>MOV.B<br>BSET<br>MOV.B | #0,PS0; Sets function select register A0 and A1.#0,PS2; Sets function select register A2.#0,PSL0; Sets function select register B0 and B1.#0,PSL2; Sets function select register B2.#0,PSC; Sets function select register C.2,PRCR; Remote protection.; (Write function select register A3 enabled)#0,PS3; Sets function select register A3. |
| ;                                     | MOV.B<br>MOV.B                                             | #03H,DS; Sets external data bus width control register.#85H,WCR; Sets wait control register.                                                                                                                                                                                                                                                 |
| ,                                     | LDC<br>LDC                                                 | #80H,FLG ; Sets initial value in flag register.(Sets U = 1)<br>#(RAM_END-ISTACK_SIZE)+1,SP ; Sets initial value in stack pointer(USP).                                                                                                                                                                                                       |
| ,                                     | MOV.W                                                      | #0FFF0H,PUR2 ; Connects internal pull-up registers to ports P6 through P10.                                                                                                                                                                                                                                                                  |
| ;<br>Declaration to the<br>assembler. | MOV.B<br>MOV.W<br>MOV.W                                    | #0FFH,03CBH ; Sets initial value in SFR reserved area.<br>#0FFFFH,03CEH<br>#0FF <u>EEH 03D2H</u><br>Values declared to the                                                                                                                                                                                                                   |
| .SB<br>.FB                            | SB_BASE<br>FB_BASE<br>LDC<br>LDC                           | #SB_BASE,SB       ; Sets initial value in SB register.         #FB_BASE,FB       ; Sets initial value in FB register.                                                                                                                                                                                                                        |
| •                                     | MOV.W<br>MOV.W                                             | #0,R0<br>#(RAM_END+1 - RAM_TOP)/2,R3 ; Clears WORK_RAM area in zero.                                                                                                                                                                                                                                                                         |
|                                       | MOV.W<br>SSTR.W                                            | #WORKRAM_TOP,A1                                                                                                                                                                                                                                                                                                                              |
| ;====                                 |                                                            | Main program                                                                                                                                                                                                                                                                                                                                 |
| ,<br>MAIN<br>;                        | I:<br>MOV.B<br>MOV.W<br>BSET                               | DATA_TABLE[A0],R0L<br>#1234H,R1<br>char_b0                                                                                                                                                                                                                                                                                                   |
| ;                                     | JMP                                                        | MAIN                                                                                                                                                                                                                                                                                                                                         |
| ;====<br>dumr                         |                                                            | Dummy interrupt program                                                                                                                                                                                                                                                                                                                      |
| ;                                     |                                                            |                                                                                                                                                                                                                                                                                                                                              |



| ;======================================    | =Fixed data area========           |                                                                        |     |
|--------------------------------------------|------------------------------------|------------------------------------------------------------------------|-----|
| ,<br>.SECTION<br>.ORG                      | CONSTANT,ROMDATA                   | ; Declares section name and section type.<br>; Declares start address. |     |
| ;<br>DATA TABLE:                           | Must be matche                     | ed to ROM area in hardware.                                            |     |
| .BYTE                                      | 12H,34H,56H,78H                    | ; Sets 1-byte data.                                                    |     |
| .WORD                                      | 1234H,5678H                        | ; Sets 2-byte data.                                                    |     |
| .ADDR                                      | 123456H,789ABCH                    | ; Sets 3-byte data.                                                    |     |
| .LWORD                                     | 12345678H,9ABCDEF0H                | ; Sets 4-byte data.                                                    |     |
| DATA_TABLE_END:                            | Set jur                            | np addresses sequentially                                              |     |
| ,<br>.************************************ |                                    | ing with the least significant                                         |     |
| ,                                          | addres                             | s of the fixed vector.                                                 |     |
| ,<br>SECTION                               | F VECT.ROMDATA                     |                                                                        |     |
| .ORG                                       | FIXED_VECT_TOP                     |                                                                        |     |
| .LWORD                                     | dummy                              | ; Undefined instruction interrupt vector                               |     |
| .LWORD                                     | dummy                              | ; Overflow (INTO instruction) interrupt vector                         |     |
| .LWORD                                     | dummy                              | ; BRK instruction interrupt vector                                     |     |
| .LWORD                                     | dummy                              | ; Address match interrupt vector                                       |     |
| .LWORD                                     | dummy                              | ; Not used.                                                            |     |
| .LWORD                                     | dummy                              | ; Watchdog timer interrupt vector                                      |     |
| .LWORD<br>.LWORD                           | dummy<br>dummy                     | ; Not used.<br>: NMI interrupt vector                                  |     |
| .LWORD                                     | START                              | : Sets reset vector.                                                   |     |
| . LWORD                                    | START                              |                                                                        |     |
| , END                                      | -                                  | Set the program start address for                                      | the |
|                                            | mp addresses for unused interru    | reactive star Immediately ofter                                        |     |
|                                            | ssing (REIT instruction only) to p |                                                                        |     |
|                                            | unning out of control when an u    | nused interrupt is deactivated, the program starts fro                 | om  |
| reque                                      |                                    | the address written in this vector.                                    |     |
|                                            |                                    |                                                                        |     |
|                                            |                                    |                                                                        |     |
| Figure 4.1.7 Desc                          | cription example 1 for in          | itial setting                                                          |     |



# 4.2 Initial Setting the CPU

Each register as well as RAM and other resources must be initial set immediately after power-on or after a reset. If the CPU internal registers remain un-set or there is unintended data left in memory before program execution, all this could cause the program to run out of control. Therefore, the internal resources must be initial set at the beginning of the program. This initial setting includes the following:

(1)Declaration to the assembler

(2)Initialization of the CPU internal registers, flags, and RAM area

- (3)Initialization of work area
- (4)Initialization of built-in peripheral functions such as port, timer, and interrupt

## 4.2.1 Setting CPU Internal Registers

After a reset, it is normally necessary to set up the registers related to the processor's operation mode, system clock, and port functions.

#### Setting the processor mode and system clock

The Processor Mode Registers 0/1, System Clock Control Registers 0/1, and Main Clock Divide Register are protected registers, so remove protection of these registers before you set them and re-protect the registers after you finished setting them. Figure 4.2.1 shows an example of how to set the registers.

| ;                                                | Setting the proces                                           | sor mode and system clock                                                                                                                                                             |
|--------------------------------------------------|--------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| , MOV.B<br>MOV.W<br>MOV.W<br>MOV.B<br>MOV.B<br>; | #03H,PRCR<br>#0183H,PM0<br>#2008H,CM0<br>#12H,MCD<br>#0,PRCR | ; Remove protection.<br>; Sets processor mode registers 0 and 1.<br>; Sets system clock control registers 0 and 1.<br>; Sets main clock divide register.<br>; Protects all registers. |

Figure 4.2.1 Example for setting the processor mode and system clock



## Setting port functions

If a pin output function in M16C/80 is multiplexed between port output and peripheral function output or a single pin is assigned multiple peripheral function outputs, it is necessary to select the desired output function using Function Select Registers. Figure 4.2.2 shows an example of how to set the Function Select Register.



#### Figure 4.2.2 Example for setting function select registers

#### 4.2.2 Setting Stack Pointer

When using a subroutine or interrupt, the return address, etc. are saved to the stack. Therefore, the stack pointer must be set before calling the subroutine or enabling the interrupt. For a setup example, refer to Section 4.2.7, "Sample Program List 2 (Initial Setting 2)".

#### 4.2.3 Setting Base Registers (SB, FB)

The M16C/80 series has an addressing mode called "base register relative addressing" to allow for efficient data access. Since a relative address from an address that serves as the base is used for access in this mode, it is necessary to set the base address before this addressing mode can be used. For a setup example, refer to Section 4.2.7, "Sample Program List 2 (Initial Setting 2)".

## 4.2.4 Setting fixed interrupt vector (reset vector)

The M16C/80 series has two types of vectors available, a variable and a fixed vector. For details on how to set the fixed interrupt vectors including a reset vector, refer to Section 4.2.6, "Sample List 2 (Initial Settings 2)."

#### 4.2.5 Setting internal peripheral functions

The following explains how to set the internal RAM, ports, timers, and DMA controller of the M16C/80 group. For details, refer to the functional description in the user's manual supplied with your microcomputer.

#### **Initial Setting Work Areas**

Normally clear the work areas to 0 by initial setting. If the initial value is not 0, set that initial value in each work area. Figure 4.2.3 shows an example for initial setting a work area.

| ;Cl<br>RAM_TOP .EQU<br>RAM_END .EQU    | 0400H                                           | string instruction                                                                           |
|----------------------------------------|-------------------------------------------------|----------------------------------------------------------------------------------------------|
| ;<br>MOV.W<br>MOV.W<br>MOV.W<br>SSTR.W | #0,R0<br>#(RAM_END + 1 - RAM<br>#WORKRAM_TOP,A1 | /_TOP) / 2,R3<br>; Transfer a 0 from WORKRAM_TOP<br>; two times for (RAM_END + 1 - RAM_TOP). |
| MOV.B                                  | etting initial values in wor<br>#0FFH,char      | k RAM<br>; Set one byte of data.                                                             |
| , MOV.B                                | #0FFFFH,short                                   | ; Set one word of data.                                                                      |
| , MOV.W<br>MOV.B                       | #0FFFFH,addr<br>#0FFH,addr + 2                  | ; Set three bytes of data.                                                                   |
| , MOV.L                                | #0FFFFFFFFH,long                                | ; Set one long word of data.                                                                 |

Figure 4.2.3 Example for initial setting a work area



#### **Initial Setting Ports**

It is when a port direction register is set for output that data is output from a port. To prevent indeterminate data from being output from ports, set the initial value in each output port before setting their direction register for output. Figure 4.2.4 shows an example for initial setting ports.



Figure 4.2.4 Example for initial setting ports

#### **Setting Timers**

When using the M16C/80 series built-in peripheral functions such as a timer, initial set the related registers (in SFR area). Figure 4.2.5 shows an example for setting timer A0.

| ;                 | Set              | ting Timer A0         |                                                                          |
|-------------------|------------------|-----------------------|--------------------------------------------------------------------------|
| ,<br>TAOR<br>TAOS | .BTEQU<br>.BTEQU | 3,TA0IC<br>0,TABSR    |                                                                          |
| ,                 | MOV.B            | #01000000B,TA0MR      | ; Set Timer A0 Mode Register.<br>; (Mode: timer mode; divide ratio: 1/8) |
|                   | MOV.W<br>BCLR    | #2500 - 1,TA0<br>TA0R | ; Set Timer A0 count value.<br>; Clear Timer A0 interrupt request bit.   |
| ;                 | BSET             | TAOS                  | ; Timer A0 starts counting.                                              |

Figure 4.2.5 Example for setting timer

Note 1: Because the Port P9 Direction Register is a protected register, set the Protect Register bit 2 to 1 to remove the protection before you set a value.

Note 2: The Port P9 Direction Register write enable bit (Protect Register bit 2) is reset to 0 by the next write instruction executed after being write-enabled. Therefore, to change a port for input or output, be sure to set the Port P9 Direction Register immediately after the instruction by which its write enable bit is set to 1. Also, make sure no interrupt or DMA transfer will occur during this time.



## Setting the DMA controller

When using the DMAC, initial set the registers associated with it (CPU internal registers and SFR area). The DMAC-related registers are shown in Figure 4.2.6.



Figure 4.2.6 DMAC-related registers

Note1: Before setting DMA2 and DMA3-related registers, always be sure to set Flag Register (FLG)'s register bank specification flag (B) to 1.

Note2: When using DMA2 and DMA3, note that fast interrupts cannot be used. Nor can the registers be saved and restored by register bank switchover in an interrupt handling routine.



## Settings when using DMA controller channels 1 to 2 (DMA0, 1)

When using DMAC channels 1 to 2, the following shows an example of how to set the related registers (CPU internal registers and SFR area).

| #32,DRC0; Set transfer count<br>in DMA0 Transfer Count Reload Register<br>; in DMA0 Transfer Count Reload Register<br>; Set transfer count in DMA0 Transfer Count Register<br>; Set source address of transfer (memory)<br>; in DMA0 Memory Address Reload Register<br>; Set destination address of transfer (memory)<br>; in DMA0 Memory Address Register<br>; Set destination address of transfer (SFR)<br>; in DMA0 SFR Address Register<br>; Set DMA Mode Register 0 and enable DMA transfer<br>; Unit of transfer: 16 bits | MOV.B | #00000011B,DM0SL | ; Set cause of DMA0 request                              |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------------------|----------------------------------------------------------|
| #32,DCT0Set transfer count in DMA0 Transfer Count Register#0FF0000H,DRA0Set source address of transfer (memory)in DMA0 Memory Address Reload Register#0FF0000H,DMA0Set destination address of transfer (memory)in DMA0 Memory Address Reload Register#06,DSA0Set destination address of transfer (SFR)#00001111B,DMD0Set DMA Mode Register 0 and enable DMA transferUnit of transfer: 16 bits                                                                                                                                   | DC    | #32,DRC0         |                                                          |
| #0FF0000H,DRA0       Set source address of transfer (memory)         in DMA0 Memory Address Reload Register         #0FF0000H,DMA0       Set destination address of transfer (memory)         in DMA0 Memory Address Register         #P6,DSA0       Set destination address of transfer (SFR)         in DMA0 SFR Address Register         #00001111B,DMD0       Set DMA Mode Register 0 and enable DMA transfer         Unit of transfer: 16 bits                                                                             |       | #20 DOT0         |                                                          |
| <ul> <li>in DMA0 Memory Address Reload Register</li> <li>Set destination address of transfer (memory)</li> <li>in DMA0 Memory Address Register</li> <li>Set destination address of transfer (SFR)</li> <li>in DMA0 SFR Address Register</li> <li>\$ Set DMA Mode Register 0 and enable DMA transfer</li> <li>Unit of transfer: 16 bits</li> </ul>                                                                                                                                                                               | DC    | - ,              |                                                          |
| #0FF0000H,DMA0; Set destination address of transfer (memory)<br>; in DMA0 Memory Address Register#P6,DSA0; Set destination address of transfer (SFR)<br>; in DMA0 SFR Address Register#00001111B,DMD0; Set DMA Mode Register 0 and enable DMA transfer<br>; Unit of transfer: 16 bits                                                                                                                                                                                                                                           | DC    | #0FF0000H,DRA0   |                                                          |
| <ul> <li>in DMA0 Memory Address Register</li> <li>#P6,DSA0</li> <li>Set destination address of transfer (SFR)</li> <li>in DMA0 SFR Address Register</li> <li>#00001111B,DMD0</li> <li>Set DMA Mode Register 0 and enable DMA transfer</li> <li>Unit of transfer: 16 bits</li> </ul>                                                                                                                                                                                                                                             |       |                  |                                                          |
| <ul> <li>#P6,DSA0</li> <li>; Set destination address of transfer (SFR)</li> <li>; in DMA0 SFR Address Register</li> <li>#00001111B,DMD0</li> <li>; Set DMA Mode Register 0 and enable DMA transfer</li> <li>; Unit of transfer: 16 bits</li> </ul>                                                                                                                                                                                                                                                                              | DC    | #0FF0000H,DMA0   |                                                          |
| #00001111B,DMD0 ; in DMA0 SFR Address Register<br>#00001111B,DMD0 ; Set DMA Mode Register 0 and enable DMA transfer<br>; Unit of transfer: 16 bits                                                                                                                                                                                                                                                                                                                                                                              |       |                  |                                                          |
| #00001111B,DMD0 ; Set DMA Mode Register 0 and enable DMA transfer<br>; Unit of transfer: 16 bits                                                                                                                                                                                                                                                                                                                                                                                                                                | _DC   | #P6,DSA0         |                                                          |
| ; Unit of transfer: 16 bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |                  | ; in DMA0 SFR Address Register                           |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | DC    | #00001111B,DMD0  |                                                          |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |                  | ; Unit of transfer: 16 bits                              |
| : Direction of transfer: Forward (memory) -> fixed (SFR)                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |                  | ; Direction of transfer: Forward (memory) -> fixed (SFR) |
| ; Transfer mode: Repeat transfer (DMA0 enabled)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |                  |                                                          |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |                  |                                                          |

Figure 4.2.7 Example 1 for setting the DMA controller

#### Settings when using 3 or more DMA controller channels (DMA2, 3)

When using 3 or more DMAC channels, the following shows an example of how to set the DMA2related registers (CPU internal registers and SFR area).

| FSET  | В                | ; Set register bank to 1                                          |
|-------|------------------|-------------------------------------------------------------------|
| MOV.B | #00001111B,DM2SL | ; Set cause of DMA2 request                                       |
| MOV.W | #16,R2           | ; Set transfer count                                              |
|       |                  | ; in DMA2 Transfer Count Reload Register (R2)                     |
| MOV.W | #16,R0           | ; Set transfer count                                              |
|       |                  | ; in DMA2 Transfer Count Register (R0)                            |
| LDC   | #U0RB,SB         | ; Set source address of transfer (SFR)                            |
|       |                  | ; in DMA2 SFR Address Register (SB)                               |
| LDC   | #0500H,SVP       | ; Set destination address of transfer (memory)                    |
|       |                  | ; in DMA2 Memory Address Reload Register (SVP)                    |
| MOV.L | #0500H,A0        | ; Set destination address of transfer (memory)                    |
|       |                  | ; in DMA2 Memory Address Register (A0)                            |
| FCLR  | В                | ; Return register bank to 0                                       |
| LDC   | #00001111B,DMD1  | ; Set DMA Mode Register 1 and enable DMA transfer                 |
|       |                  | ; Unit of transfer: 16 bits                                       |
|       |                  | ; Direction of transfer: Fixed (SFR) -> forward direction (memory |
|       |                  | ; Transfer mode: Repeat transfer (DMA2 enabled)                   |

Figure 4.2.8 Example 1 for setting the DMA controller

Note: When using two or less DMAC channels, try using DMA0 and DMA1 as much as possible. If DMA2 and DMA3 are used, Register Bank 1 and fast interrupts become unusable.





# 4.2.6 Sample Program List 2 (Initial Setting 2)

|             | ,<br>.INC                      | CLUDE        | M3800                   | INC.          |                 |                                                                      |                                                                                                        |  |
|-------------|--------------------------------|--------------|-------------------------|---------------|-----------------|----------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|--|
|             | ;<br>.***********              | ****** Defin | ed symb                 | ol ****       | ******          | *****                                                                | ****                                                                                                   |  |
|             | ;                              |              | -                       |               |                 | <b>0</b> 1                                                           |                                                                                                        |  |
|             | RAM_TOP<br>RAM_END             |              | .EQU<br>.EQU            | 00040<br>002B |                 |                                                                      | address of RAM<br>address of RAM                                                                       |  |
|             | ROM TOP                        |              | .EQU                    | 062B          |                 |                                                                      | address of ROM                                                                                         |  |
|             | FIXED_VEC                      |              | .EQU                    |               |                 |                                                                      | address of fixed vector                                                                                |  |
|             | SB_BASE                        |              | .EQU                    | 00400         |                 | ;Base address of SB relative<br>:Base address of FB relative         |                                                                                                        |  |
|             | FB_BASE                        |              | .EQU                    | 00580         |                 |                                                                      |                                                                                                        |  |
|             | ;<br>.SECTION                  |              | .EQU                    | 300H          |                 |                                                                      | of interrupt stack area                                                                                |  |
|             |                                |              | ated wor                | k RAM         | area ******     | *****                                                                | ******                                                                                                 |  |
|             |                                |              | WORK,DATA               |               |                 |                                                                      |                                                                                                        |  |
|             | OR.<br>WORKRAM                 |              | RAM_1                   | OP            |                 |                                                                      |                                                                                                        |  |
|             | WORK_1:                        |              | .BLKB                   |               | 1               |                                                                      |                                                                                                        |  |
|             | WORK_2:                        |              | .BLKB                   |               | 1 ,             |                                                                      |                                                                                                        |  |
|             | WORKRAM                        | I_END:       |                         |               |                 |                                                                      | prevent the program from going wild when the NMI                                                       |  |
|             | ;<br>;<br>.************        | *******      | *** Progr               | am arc        | ******** c      |                                                                      | errupt (nonmaskable) is generated inadvertently                                                        |  |
|             |                                |              |                         |               |                 |                                                                      | er a reset, set the interrupt stack pointer (ISP) at the<br>ginning of startup procedure.              |  |
|             | ;                              | CTION        |                         |               |                 |                                                                      |                                                                                                        |  |
|             | .5E<br>.OR                     |              | PROGRAM,CODE<br>ROM_TOP |               | ODE             | ;Declares section name and section type.<br>;Declares start address. |                                                                                                        |  |
|             | START:                         |              | nom_                    |               |                 |                                                                      |                                                                                                        |  |
|             |                                | LDC          |                         | #RAN          | 1_END + 1,      | ISP                                                                  | ;Sets initial value in stack pointer(ISP).                                                             |  |
|             | ,                              | MOV.E        | <br>>                   | #0211         | PRCR            |                                                                      | Demovies protetion                                                                                     |  |
|             |                                | MOV.         |                         |               | ,FROR<br>3H,PM0 |                                                                      | ;Removes protction.<br>;Sets processor mode register 0 and 1.                                          |  |
|             | 1                              | MOV.V        |                         |               | 3H,CM0          |                                                                      | ;Sets system clock control registers 0 and 1.                                                          |  |
|             |                                | MOV.E        | 3                       | #12H          | ,MCD            |                                                                      | ;Sets main clock divide register.                                                                      |  |
|             | . //                           | MOV.E        | 3                       | #0,PF         | RCR             |                                                                      | ;Protects all register.                                                                                |  |
|             | , //                           | MOV.V        | V                       | #0,PS         | 50              |                                                                      | ;Sets function select register A0 and A1.                                                              |  |
|             | //                             | MOV.E        |                         | #0,PS         |                 |                                                                      | ;Sets function select register A2.                                                                     |  |
| /           | //                             | MOV.V        |                         | #0,PS         |                 |                                                                      | ;Sets function select register B0 and B1.                                                              |  |
|             | /                              | MOV.E        |                         | #0,PS         |                 |                                                                      | ;Sets function select register B2.                                                                     |  |
| _ / /       |                                | MOV.E        | 5                       | #0,PS         |                 |                                                                      | ;Sets function select register C.<br>;Removes protection.                                              |  |
|             |                                | DOCI         |                         | 2,PR          |                 |                                                                      | ;(Writes to pin function select register A3 enable)                                                    |  |
| //          |                                | MOV.E        | 3                       | #0,PS         | 33              |                                                                      | ;Sets function select register A3.                                                                     |  |
|             | 1                              | F            |                         |               |                 |                                                                      |                                                                                                        |  |
|             | ed registers s<br>emove protec |              |                         |               |                 |                                                                      |                                                                                                        |  |
|             | n you finished                 |              |                         |               | Because         | Pin (                                                                | Dutput Function Select Register 3 is a protected                                                       |  |
| eprotect th |                                |              | - 3.0.01                | - 7           |                 |                                                                      | ve its protection before setting it.                                                                   |  |
|             |                                |              |                         |               | Also, the       | Pin (                                                                | Dutput Function Select Register 3 write enable bit (                                                   |  |
|             |                                |              |                         |               |                 |                                                                      | er bit 3) is reset to 0 by the next write instruction                                                  |  |
|             |                                |              |                         |               |                 |                                                                      | being write-enabled. Therefore, when setting initial                                                   |  |
|             |                                |              |                         |               |                 |                                                                      | sure the value is set in Pin Output Function Select nediately after the instruction by which its write |  |
|             |                                |              |                         |               |                 | JULI                                                                 |                                                                                                        |  |

# RENESAS

| Addresses 03C9H and 03CBH to 03D3H<br>in the SFR area are reserved for use by<br>products to be developed in the future.<br>Always be sure to initialize addresses 03<br>CBH, 03CEH, 03CFH, 03D2H, and 03D3<br>H with the value "FFH."<br>; | MOV.B<br>MOV.B<br>LDC<br>LDC<br>MOV.W<br>MOV.W | #03H,DS<br>#85,WCR<br>#80H,FLG<br>#(RAM_END - ISTACK<br>#003FFH,PUR2<br>#0FFH,03CBH<br>#0FFFFH,03CEH<br>#0FFFFH,03D2H | ;Sets external data bus width control register.<br>;Sets wait control register.<br>;Sets initial value flag register(U=1).<br>(_SIZE) +1 ,SP ;Sets initial value in stack pointer(USP).<br>;Connects internal pull-up registers to ports P6 through P10<br>;Sets initial value in SFR reserved area. |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| .SB<br>.FB                                                                                                                                                                                                                                  | SB_BASE                                        | Must always b                                                                                                         | be consistent. Fregister value to the assembler.<br>;Declares FB register value to the assembler.                                                                                                                                                                                                    |
|                                                                                                                                                                                                                                             | LDC<br>LDC                                     | #SB_BASE,SB<br>#FB_BASE,FB                                                                                            | ;Sets initial value in SB register.<br>;Sets initial value in FB register.                                                                                                                                                                                                                           |
| Before RAM access (using SB or FB<br>relative addressing), set the SB and<br>FB registers.                                                                                                                                                  | MOV.W<br>MOV.W<br>MOV.W<br>SSTR.W              | #0,R0<br>#(RAM_END + 1 - RA<br>#WORKRAM_TOP,A1                                                                        |                                                                                                                                                                                                                                                                                                      |
| MAI                                                                                                                                                                                                                                         | N:                                             | 1 0                                                                                                                   |                                                                                                                                                                                                                                                                                                      |
| MAI                                                                                                                                                                                                                                         | JSR<br>N 10:                                   | INIT                                                                                                                  | ;Sets initial value in work RAM.                                                                                                                                                                                                                                                                     |
|                                                                                                                                                                                                                                             | BTST                                           | TAOR                                                                                                                  | ;Determines TA0 interrupt request flag.                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                                                                             | JNC<br>BCLR                                    | MAIN_10<br>TA0R                                                                                                       |                                                                                                                                                                                                                                                                                                      |
|                                                                                                                                                                                                                                             | JSR                                            | SUB_TA0                                                                                                               | ;Processes timer A0.                                                                                                                                                                                                                                                                                 |
| · ,                                                                                                                                                                                                                                         |                                                |                                                                                                                       |                                                                                                                                                                                                                                                                                                      |
| -<br>,                                                                                                                                                                                                                                      | JMP                                            | MAIN_10                                                                                                               |                                                                                                                                                                                                                                                                                                      |
| ,<br>,                                                                                                                                                                                                                                      |                                                | INIT routing                                                                                                          |                                                                                                                                                                                                                                                                                                      |
| ,===<br>INIT                                                                                                                                                                                                                                |                                                |                                                                                                                       |                                                                                                                                                                                                                                                                                                      |
| ,<br>-                                                                                                                                                                                                                                      |                                                | Initial setting work R                                                                                                | AM and ports                                                                                                                                                                                                                                                                                         |
| ,                                                                                                                                                                                                                                           | MOV.B                                          | #0FFH,WORK 1                                                                                                          |                                                                                                                                                                                                                                                                                                      |
|                                                                                                                                                                                                                                             | MOV.B                                          | #0FFH,WORK_2                                                                                                          |                                                                                                                                                                                                                                                                                                      |
|                                                                                                                                                                                                                                             | MOV.B                                          | #0FFH,P6                                                                                                              |                                                                                                                                                                                                                                                                                                      |
| ,<br>;                                                                                                                                                                                                                                      |                                                | Setting timer A0                                                                                                      |                                                                                                                                                                                                                                                                                                      |
| • • •                                                                                                                                                                                                                                       |                                                | #0100000B TACME                                                                                                       | :Sata timer A0 mode register                                                                                                                                                                                                                                                                         |
|                                                                                                                                                                                                                                             | MOV.B<br>MOV.W                                 | #01000000B,TA0MR<br>#2500 - 1,TA0                                                                                     | ;Sets timer A0 mode register.<br>:Sets timer A0 count value.                                                                                                                                                                                                                                         |
|                                                                                                                                                                                                                                             | BCLR                                           | TAOR                                                                                                                  | Clears timer A0 interrupt request                                                                                                                                                                                                                                                                    |
|                                                                                                                                                                                                                                             | BSET                                           | TA0S                                                                                                                  | ;Timer A0 start counting. registers, set the count start flag.                                                                                                                                                                                                                                       |
|                                                                                                                                                                                                                                             |                                                |                                                                                                                       |                                                                                                                                                                                                                                                                                                      |



| ·                         |                  | Setting DMA0                                                    |                                                                                        |
|---------------------------|------------------|-----------------------------------------------------------------|----------------------------------------------------------------------------------------|
| ,                         | MOV.B<br>LDC     | #00000011B,DM0SL<br>#32,DRC0                                    | ;Sets cause of DMA request.<br>:Sets transfer count.                                   |
|                           | LDC              | #32,DRC0                                                        |                                                                                        |
| ,                         | LDC              | #32,DCT0                                                        | ;Sets transfer count in DMA0 transfer count register.                                  |
|                           | LDC              | #0FF0000H,DRA0                                                  | ;Sets source address of transfer(memory)<br>;in DMA0 memory address reload register.   |
|                           | LDC              | #0FF0000H,DMA0                                                  | ;Sets destination address of transfer(memory)<br>in DMA0 memory address register.      |
|                           | LDC              | #P6,DSA0                                                        | ;sets destination address of transfer(SFR)<br>in DMA0 SFR address register.            |
|                           | LDC              | #00001111B,DMD0                                                 | ;Sets DMA mode register 0 and enable DMA transfer                                      |
|                           |                  |                                                                 | ;Unit of transfer : 16 bits<br>;Direction of transfer : Forward(memory)->fixed(SFR)    |
| INIT_E                    | END:             | After setting all of DMA-relative registers, enable DMA (set of | ted ;Transfer mode : Repeat transfer(DMA0 enable)                                      |
|                           | RTS [            | transfer mode select bit)                                       |                                                                                        |
| ;====<br>SUB <sup>-</sup> |                  | ====== SUB_1/                                                   | A0 routine ====================================                                        |
| 000_                      | MOV.B            | WORK_1,R0L                                                      |                                                                                        |
|                           | INC.B            | R0L                                                             |                                                                                        |
| ,                         |                  |                                                                 |                                                                                        |
| ,<br>SUB_                 | TA0_END:         |                                                                 |                                                                                        |
|                           | RTS              |                                                                 |                                                                                        |
| ;=====                    |                  | ===== Dummv                                                     | / interrupt program ====================================                               |
| dumm                      | iy:              | ,                                                               |                                                                                        |
|                           | REIT             |                                                                 |                                                                                        |
| ,<br>.******<br>,         | **********       | **************************************                          | fixed vectors ************************************                                     |
|                           | .SECTIOI<br>.ORG | N F_VECT,ROMDATA<br>FIXED VECT TOP                              |                                                                                        |
| ;                         |                  |                                                                 |                                                                                        |
|                           | .LWORD<br>.LWORD | dummy<br>dummy                                                  | ;Undefined instruction interrupt vector<br>;Overflow(INTO instruction)interrupt vector |
|                           | .LWORD           | dummy                                                           | ;BRK instruction interrupt vector                                                      |
|                           | .LWORD           | dummy                                                           | ;Address match interrupt vector                                                        |
|                           | .LWORD           | dummy                                                           | ;Unused                                                                                |
|                           | .LWORD           | dummy                                                           | ;Watchdog timer interrupt vector                                                       |
|                           | .LWORD<br>.LWORD | dummy<br>dummy                                                  | ;Unused<br>;NMI interrupt vector                                                       |
|                           | .LWORD           | START                                                           | ;Sets reset vector.                                                                    |
|                           | .END             |                                                                 |                                                                                        |
| Figure                    | e 4.2.9 D        | escription example 2                                            | ? for initial setting                                                                  |
|                           |                  |                                                                 |                                                                                        |

# 4.3 Setting when using Interrupts

**(ENESAS** 

This section describes the processing and the method of description necessary to execute interrupt handling routines, as well as how to execute multiple interrupts. Before an interrupt can be generated in the M16C/80 series, all of the following three conditions must be met:

(1)Interrupt enable flag (I) = 1 (interrupt enabled)

(2)IPL < Software interrupt priority level of the interrupt generated

(3)Interrupt request bit for the interrupt used = 1 (interrupt requested)

In addition to the above three conditions, following processing are required before an interrupt handling routine can be executed:

(1) Set Interrupt Table Register (INTB)

- (2) Set variable/fixed vectors
- (3) Set Interrupt Control Register
- (4) Enable interrupt enable flag (I)
- (5) Save and restore registers in interrupt handling routine

## 4.3.1 Setting Interrupt Table Register(INTB)

Since the vector tables for interrupts from internal peripheral functions in the M16C/80 series are variable, it is necessary to set the start address of the vector using Interrupt Table Register (INTB) before using interrupts.

The 256 bytes of space from the address specified by the Interrupt Table Register is the variable vector area, with each vector consisting of 4 bytes. Each vector is assigned a software interrupt number, together comprising 64 vectors from 0 to 63.

For setup examples, refer to Section 4.3.6, "Sample List 3 (Using Interrupts)."

# 4.3.2 Setting Variable/Fixed Vectors

When an interrupt occurs, the program jumps to the address that has been set for each cause of interrupt. The part of memory in which this jump address is set is referred to as the "interrupt vector." To set interrupt vectors, register the start address of each interrupt handler program in the variable/fixed vector table. For an example of how the vectors actually are registered, refer to Section 4.3.6, "Sample Program List 3 (Software Interrupt)".

#### Variable Vector Table

The variable vector table is a 256-byte interrupt vector table that starts from the address specified by Interrupt Table Register (INTB). The vector table can be located anywhere in memory space except the SFR area. One vector consists of 4 bytes, with each vector assigned software interrupt numbers 0 to 63.



# 4.3.3 Setting Interrupt Control Register

Bits 0-2 of each interrupt control register can be used to set the interrupt priority level of each interrupt. When level = 0, the effect is the same as interrupts being disabled, so make sure the priority levels set are equal to or greater than 1. The Interrupt Control Register bit 3 serves as an interrupt request flag. This flag is 0 after a reset, but because this flag for some external pin interrupt may have been set to 1, be sure to clear it to 0 before enabling the interrupt enable flag (I flag). For setup examples, refer to Section 4.3.6, "Sample List 3 (Using Interrupts)."

For details about the bit configuration and priority levels of each interrupt control register, consult the user's manual supplied with your microcomputer.

# 4.3.4 Enabling Interrupt Enable Flag( I flag)

Immediately after power-on and after a reset, interrupts are in disabled state. Therefore, interrupts must be enabled in the program. This can be accomplished by setting the Flag Register (FLG)'s I flag to 1. Because interrupts are enabled at the same time the I flag is set to 1, caution must be used to prevent the program from going wild. To this end, always be sure to enable the I flag after making initial settings, and not at the beginning of the program.

## 4.3.5 Saving and Restoring Registers in Interrupt Handler Routine

When an interrupt is accepted, the following resources are automatically saved to the stack. For details on how they are saved and restored to and from the stack, refer to Section 4.5.2, "Stack Area."

(1)Contents of PC (program counter)

(2)Contents of FLG (flag register)

Always be sure to use the REIT instruction to return from the interrupt handler routine. After the interrupt processing is completed, this instruction restores the registers, return address, etc. from the stack, thus

Except for automatically saved registers, if there are any registers that are likely to be modified in the interrupt handling routine (e.g., registers used in interrupt handling), save them to the stack in software. For an example of how to save and restore registers in an interrupt handling routine, refer to Figures 4.3.2 and 4.3.3.

#### Methods for Saving and Restoring Registers

If in addition to the automatically saved registers there is any register which is used in the interrupt handler routine and, therefore, whose previous content needs to be retained, save it to the stack area in software. There are two methods for saving and restoring this register. The following shows the processing procedure for each method.

There are following two methods for saving/restoring registers.

#### (1) Saving and restoring by push/pop instructions

(1a) Saving registers individually PUSH.B R0L

- PUSH.W R1
- (1b) Restoring registers individually

POP.B R0L POP.W R1

- (2a) Saving registers collectively PUSHM R0,R1,R2,R3,A0,A1
   (2b) Restoring registers collectively
  - POPM R0,R1,R2,R3,A0,A1

#### (2) Saving and restoring by register bank switchover

This method is effective when a reduction in interrupt handling overhead time is desired.

(a) Using register bank 1 FSET B

(b) Using register bank 0

FCLR B



## **Description of Interrupt Handling Program(1)**



Note: If both register banks 0 and 1 are used in the main program, the method for saving and restoring registers by register bank switchover cannot be used.



## **Description of Interrupt Handling Program(2)**

If high-speed interrupt acknowledgment is desired, use the register bank switchover shown below<sup>(Note)</sup>.

Registers (R0, R1, R2, R3, A0, A1, SB, and FB) can be saved/restored by one instruction, "FSET B" or "FCLR B" (number of execution cycles: 1).



Note: If register banks 0 and 1 both are being used in the main program, registers cannot be saved/restored by register bank switchover.



# 4.3.6 Sample Program List 3 (Using interrupts)

| .INCLUDE                                      |                                                                                                                                                  | M30800.INC                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
|-----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| *******                                       | *************** Define                                                                                                                           | e symbol *********************                                                                                                                                               | *********                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
|                                               |                                                                                                                                                  | -                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| I_TOP                                         |                                                                                                                                                  | .EQU 000400H<br>.EQU 002BFFH                                                                                                                                                 | ; Start address of RAM<br>: End address of RAM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| 1_TOP                                         |                                                                                                                                                  | .EQU 0FE0000H                                                                                                                                                                | : Start address of ROM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| XED_VECT_TOP<br>B_BASE<br>3_BASE<br>TACK_SIZE |                                                                                                                                                  | .EQU 0FFFFDCH                                                                                                                                                                | ; Start address of fixed vector                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
|                                               |                                                                                                                                                  | .EQU 00400H                                                                                                                                                                  | ; Base address for SB relative<br>; Base address for FB relative<br>; Size of interrupt stack area                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
|                                               |                                                                                                                                                  | .EQU 00580H<br>.EQU 300H                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
|                                               |                                                                                                                                                  |                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| *******                                       | ********** Allocat                                                                                                                               | ted work RAM area ********                                                                                                                                                   | ********************                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| .SE                                           | CTION                                                                                                                                            | WORK,DATA                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| .OR                                           |                                                                                                                                                  | RAM_TOP                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
|                                               | I_TOP:                                                                                                                                           |                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| RK_1:<br>L:                                   |                                                                                                                                                  | .BLKW 1<br>.BLKW 1                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| _E.<br>_H:                                    |                                                                                                                                                  | .BLKW 1                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
|                                               |                                                                                                                                                  |                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| RKRAN                                         | I_END.                                                                                                                                           |                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
|                                               |                                                                                                                                                  | n area **********************************                                                                                                                                    | *****                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
| *******                                       | ********Program                                                                                                                                  | n area **********************************                                                                                                                                    | *****************************                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| *******                                       | ********Program<br>======Sta                                                                                                                     | artup====================================                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| *******                                       | Program<br>Sta<br>CTION                                                                                                                          |                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
|                                               | *********Program<br>====== Sta<br>CTION<br>tG                                                                                                    | artup======<br>PROGRAM,CODE<br>ROM_TOP                                                                                                                                       | ; Declares section name and section type.<br>; Declares start address.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
|                                               | Program<br>Sta<br>CTION                                                                                                                          | PROGRAM,CODE                                                                                                                                                                 | ; Declares section name and section type.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
|                                               | *********Program<br>====== Sta<br>CTION<br>tG                                                                                                    | artup======<br>PROGRAM,CODE<br>ROM_TOP<br>#RAM_END+1,ISP                                                                                                                     | ; Declares section name and section type.<br>; Declares start address.<br>; Sets initial value in stack pointer (ISP).                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
|                                               | CTION<br>CTION<br>CG<br>LDC<br>MOV.B<br>MOV.W                                                                                                    | artup======<br>PROGRAM,CODE<br>ROM_TOP                                                                                                                                       | ; Declares section name and section type.<br>; Declares start address.<br>; Sets initial value in stack pointer (ISP).<br>; Removes protection.<br>; Sets processor mode register 0 and 1.                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
|                                               | CTION<br>CTION<br>CG<br>LDC<br>MOV.B<br>MOV.W<br>MOV.W                                                                                           | artup======<br>PROGRAM,CODE<br>ROM_TOP<br>#RAM_END+1,ISP<br>#03H,PRCR<br>#0183H,PM0<br>#2008H,CM0                                                                            | ; Declares section name and section type.<br>; Declares start address.<br>; Sets initial value in stack pointer (ISP).<br>; Removes protection.<br>; Sets processor mode register 0 and 1.<br>; Sets system clock control registers 0 and 1.                                                                                                                                                                                                                                                                                                                                   |  |  |
|                                               | CTION<br>CTION<br>CG<br>LDC<br>MOV.B<br>MOV.W<br>MOV.W<br>MOV.W                                                                                  | artup======<br>PROGRAM,CODE<br>ROM_TOP<br>#RAM_END+1,ISP<br>#03H,PRCR<br>#0183H,PM0<br>#2008H,CM0<br>#12H,MCD                                                                | ; Declares section name and section type.<br>; Declares start address.<br>; Sets initial value in stack pointer (ISP).<br>; Removes protection.<br>; Sets processor mode register 0 and 1.<br>; Sets system clock control registers 0 and 1.<br>; Sets main clock divide register.                                                                                                                                                                                                                                                                                             |  |  |
|                                               | CTION<br>CTION<br>CG<br>LDC<br>MOV.B<br>MOV.W<br>MOV.W                                                                                           | artup======<br>PROGRAM,CODE<br>ROM_TOP<br>#RAM_END+1,ISP<br>#03H,PRCR<br>#0183H,PM0<br>#2008H,CM0                                                                            | ; Declares section name and section type.<br>; Declares start address.<br>; Sets initial value in stack pointer (ISP).<br>; Removes protection.<br>; Sets processor mode register 0 and 1.<br>; Sets system clock control registers 0 and 1.                                                                                                                                                                                                                                                                                                                                   |  |  |
|                                               | CTION<br>CTION<br>CG<br>LDC<br>MOV.B<br>MOV.W<br>MOV.W<br>MOV.W                                                                                  | artup======<br>PROGRAM,CODE<br>ROM_TOP<br>#RAM_END+1,ISP<br>#03H,PRCR<br>#0183H,PM0<br>#2008H,CM0<br>#12H,MCD                                                                | ; Declares section name and section type.<br>; Declares start address.<br>; Sets initial value in stack pointer (ISP).<br>; Removes protection.<br>; Sets processor mode register 0 and 1.<br>; Sets system clock control registers 0 and 1.<br>; Sets main clock divide register.                                                                                                                                                                                                                                                                                             |  |  |
|                                               | CTION<br>CTION<br>CG<br>LDC<br>MOV.B<br>MOV.W<br>MOV.W<br>MOV.B<br>MOV.B<br>MOV.B                                                                | artup======<br>PROGRAM,CODE<br>ROM_TOP<br>#RAM_END+1,ISP<br>#03H,PRCR<br>#0183H,PM0<br>#2008H,CM0<br>#12H,MCD<br>#0,PRCR                                                     | <ul> <li>; Declares section name and section type.</li> <li>; Declares start address.</li> <li>; Sets initial value in stack pointer (ISP).</li> <li>; Removes protection.</li> <li>; Sets processor mode register 0 and 1.</li> <li>; Sets system clock control registers 0 and 1.</li> <li>; Sets main clock divide register.</li> <li>; protects all registers.</li> <li>; Sets function select register A0 and A1.</li> <li>; Sets function select register A2.</li> </ul>                                                                                                 |  |  |
|                                               | CTION<br>CTION<br>CDC<br>LDC<br>MOV.B<br>MOV.W<br>MOV.W<br>MOV.B<br>MOV.B<br>MOV.B<br>MOV.B<br>MOV.B<br>MOV.B<br>MOV.W                           | artup======<br>PROGRAM,CODE<br>ROM_TOP<br>#RAM_END+1,ISP<br>#03H,PRCR<br>#0183H,PM0<br>#2008H,CM0<br>#12H,MCD<br>#0,PRCR<br>#0,PS0<br>#0,PS2<br>#0,PSL0                      | <ul> <li>; Declares section name and section type.</li> <li>; Declares start address.</li> <li>; Sets initial value in stack pointer (ISP).</li> <li>; Removes protection.</li> <li>; Sets processor mode register 0 and 1.</li> <li>; Sets system clock control registers 0 and 1.</li> <li>; Sets main clock divide register.</li> <li>; protects all registers.</li> <li>; Sets function select register A0 and A1.</li> <li>; Sets function select register B0 and B1.</li> </ul>                                                                                          |  |  |
|                                               | CTION<br>CTION<br>CDC<br>LDC<br>MOV.B<br>MOV.W<br>MOV.W<br>MOV.B<br>MOV.B<br>MOV.B<br>MOV.B<br>MOV.B<br>MOV.B<br>MOV.B                           | artup======<br>PROGRAM,CODE<br>ROM_TOP<br>#RAM_END+1,ISP<br>#03H,PRCR<br>#0183H,PM0<br>#2008H,CM0<br>#12H,MCD<br>#0,PRCR<br>#0,PS0<br>#0,PS2<br>#0,PSL0<br>#0,PSL2           | <ul> <li>; Declares section name and section type.</li> <li>; Declares start address.</li> <li>; Sets initial value in stack pointer (ISP).</li> <li>; Removes protection.</li> <li>; Sets processor mode register 0 and 1.</li> <li>; Sets system clock control registers 0 and 1.</li> <li>; Sets main clock divide register.</li> <li>; protects all registers.</li> <li>; Sets function select register A0 and A1.</li> <li>; Sets function select register B0 and B1.</li> <li>; Sets function select register B2.</li> </ul>                                             |  |  |
|                                               | CTION<br>CTION<br>CG<br>LDC<br>MOV.B<br>MOV.W<br>MOV.W<br>MOV.B<br>MOV.B<br>MOV.B<br>MOV.B<br>MOV.B<br>MOV.B<br>MOV.B<br>MOV.B<br>MOV.B<br>MOV.B | artup======<br>PROGRAM,CODE<br>ROM_TOP<br>#RAM_END+1,ISP<br>#03H,PRCR<br>#0183H,PM0<br>#2008H,CM0<br>#12H,MCD<br>#0,PRCR<br>#0,PS0<br>#0,PS2<br>#0,PSL0<br>#0,PSL2<br>#0,PSC | <ul> <li>; Declares section name and section type.</li> <li>; Declares start address.</li> <li>; Sets initial value in stack pointer (ISP).</li> <li>; Removes protection.</li> <li>; Sets processor mode register 0 and 1.</li> <li>; Sets system clock control registers 0 and 1.</li> <li>; Sets main clock divide register.</li> <li>; protects all registers.</li> <li>; Sets function select register A0 and A1.</li> <li>; Sets function select register B0 and B1.</li> <li>; Sets function select register B2.</li> <li>; Sets function select register C.</li> </ul> |  |  |
|                                               | CTION<br>CTION<br>CDC<br>LDC<br>MOV.B<br>MOV.W<br>MOV.W<br>MOV.B<br>MOV.B<br>MOV.B<br>MOV.B<br>MOV.B<br>MOV.B<br>MOV.B                           | artup======<br>PROGRAM,CODE<br>ROM_TOP<br>#RAM_END+1,ISP<br>#03H,PRCR<br>#0183H,PM0<br>#2008H,CM0<br>#12H,MCD<br>#0,PRCR<br>#0,PS0<br>#0,PS2<br>#0,PSL0<br>#0,PSL2           | <ul> <li>; Declares section name and section type.</li> <li>; Declares start address.</li> <li>; Sets initial value in stack pointer (ISP).</li> <li>; Removes protection.</li> <li>; Sets processor mode register 0 and 1.</li> <li>; Sets system clock control registers 0 and 1.</li> <li>; Sets main clock divide register.</li> <li>; protects all registers.</li> <li>; Sets function select register A0 and A1.</li> <li>; Sets function select register B0 and B1.</li> <li>; Sets function select register B2.</li> </ul>                                             |  |  |



|                                        | MOV.B<br>MOV.B                    | #03H,DS<br>#85H,WCR                                 | ; Sets External data bus width control register.<br>; Sets wait control register.                                                                                                |  |  |
|----------------------------------------|-----------------------------------|-----------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| ,                                      | LDC #80H,<br>LDC #(RAN            | ·                                                   | ; Sets initial value in flag register(U = 1).                                                                                                                                    |  |  |
| ;                                      | MOV.W                             | #003FFH,PUR2                                        | ; Connects internal pull-up registers to ports P6 through P10                                                                                                                    |  |  |
| ,                                      | MOV.B<br>MOV.W<br>MOV.W           | #0FFH,03CBH<br>#0FFFFH,03CEH<br>#0FFFFH,03D2H       | ; Sets initial value in SFR reserved area.                                                                                                                                       |  |  |
| ;<br>.SB<br>.FB                        |                                   | BASE,SB<br>BASE,FB                                  | ; Declares SB register value to the assembler.<br>; Declares FB register value to the assembler.<br>; Sets initial value in SB register.<br>; Sets initial value in FB register. |  |  |
|                                        | MOV.W<br>MOV.W<br>MOV.W<br>SSTR.W | #0,R0<br>#(RAM_END+1 - RAM_1<br>#WORKRAM_TOP,A1     |                                                                                                                                                                                  |  |  |
| ;===================================== | =======iviain pr                  | ogram =============                                 |                                                                                                                                                                                  |  |  |
|                                        | JSR                               | INIT                                                | <u>; Sets initial value in work RAM.</u>                                                                                                                                         |  |  |
|                                        | FSET                              | <u> </u>                                            | ; Enable interrupts.                                                                                                                                                             |  |  |
| MAIN_10:<br>;                          | MOV.W<br>MULU.W                   | #5,WORK_1<br>WORK_1,ANS_L                           | Interrupts are enabled<br>after making initial<br>settings.                                                                                                                      |  |  |
| ;                                      |                                   |                                                     |                                                                                                                                                                                  |  |  |
| ;                                      | JMP                               | MAIN_10                                             |                                                                                                                                                                                  |  |  |
| ;========                              | ====== INIT ra                    | outine ====================================         | ====<br>For interrupts to be                                                                                                                                                     |  |  |
| INIT:                                  | MOV.W<br>MOV.W<br>MOV.W           | #0,WORK_1<br>#0,ANS_L<br>#0,ANS_H                   | generated, the priority<br>level must be set to any<br>value equal to or greater<br>than 1.                                                                                      |  |  |
| ,                                      | MOV.B<br>MOV.W<br>MOV.B           | #01000000B,TA0MR<br>#2500-1,TA0<br>#00000111B,TA0IC | ; Sets timer A0 mode register.<br>; Sets timer A0 count value.<br>; Sets interrupt priority level for timer A0                                                                   |  |  |
|                                        |                                   | #000001110,1A0IO                                    | ; (level : 7) and clears interrupt request bit.                                                                                                                                  |  |  |
|                                        | BCLR<br>BSET                      | TAOR<br>TAOS                                        | ; Clears timer A0 interrupt request bit.<br>; Timer A0 starts counting.                                                                                                          |  |  |
| INIT_END:                              | RTS                               |                                                     |                                                                                                                                                                                  |  |  |



| Γ_TA0: |                   |                                       | ne ====================================                                                     |
|--------|-------------------|---------------------------------------|---------------------------------------------------------------------------------------------|
|        |                   |                                       |                                                                                             |
|        |                   |                                       |                                                                                             |
|        | Dr                | •<br>arom                             |                                                                                             |
|        | PI                | ogram                                 |                                                                                             |
|        |                   | •                                     | To return from interrupt, use REIT instruction, and not RTS instruction                     |
|        | POPM              | R0,R1,R2,R3,A0,A                      | .1 ;Restores registers.                                                                     |
| Г_ТА0_ |                   |                                       |                                                                                             |
|        | ===== Du          | <pre>immy interrupt program ===</pre> |                                                                                             |
| mmy:   | REIT              |                                       |                                                                                             |
|        | IXEII             |                                       | Because vector numbers 1 to 7 are assigned<br>internal peripheral function interrupts, this |
| ****** | ************** Se | etting variable vector table *        | statement sets an address 32 bytes (4 bytes x                                               |
| -      |                   |                                       | 8) forward from the start address of the variable                                           |
|        | SECTION<br>DRG    | VECT,ROMDATA<br>VECT_TOP              | interrupt vector, that is, the address of vector                                            |
|        |                   |                                       | number 8.                                                                                   |
| .L     | WORD              | dummy                                 | ; BRK instruction interrupt vector                                                          |
|        | ORG               | VECT_TOP + (8 * 4 )                   |                                                                                             |
|        | WORD              | dummy                                 | ; DMA0 interrupt vector.                                                                    |
| .L     | WORD              | dummy                                 | ; DMA1 interrupt vector.                                                                    |
|        | WORD              | dummy                                 | ; DMA2 interrupt vector.                                                                    |
|        | WORD              |                                       | ; DMA3 interrupt vector.                                                                    |
| .L     | WORD              | INT_TA0                               | ; Sets start address of interrupt handler for<br>; Timer A0 interrupt vector.               |
|        | WORD              | dummy                                 | ; Timer A1 interrupt vector.                                                                |
|        | WORD              | dummy                                 | ; Timer A2 interrupt vector.                                                                |
|        | WORD              | dummy                                 | ; Timer A3 interrupt vector.                                                                |
| .L     | WORD              | dummy                                 | ; Timer A4 interrupt vector.                                                                |
|        | WORD              | dummy                                 | ; UART 0 transfer interrupt vector.                                                         |
|        | WORD              | dummy                                 | ; UART 0 receive interrupt vector.                                                          |
|        | .WORD<br>.WORD    | dummy<br>dummy                        | ; UART 1 transfer interrupt vector.<br>; UART 1 receive interrupt vector.                   |
|        | WORD              | dummy                                 | ; Timer B0 interrupt vector.                                                                |
|        | WORD              | dummy                                 | ; Timer B1 interrupt vector.                                                                |
|        | WORD              | dummy                                 | ; Timer B2 interrupt vector.                                                                |
|        | WORD              | dummy                                 | ; Timer B3 interrupt vector.                                                                |
|        | WORD              | dummy                                 | ; Timer B4 interrupt vector.                                                                |
|        | WORD              | dummy                                 | ; INT5 interrupt vector.                                                                    |
|        | .WORD<br>.WORD    | dummy<br>dummy                        | ; INT4 interrupt vector.<br>; INT3 interrupt vector.                                        |
|        | WORD              | dummy                                 | ; INT2 interrupt vector.                                                                    |
|        | WORD              | dummy                                 | ; INT1 interrupt vector.                                                                    |
|        | WORD              | dunmy                                 | ; INT0 interrupt vector.                                                                    |
|        |                   | <u> </u>                              |                                                                                             |
|        |                   |                                       | pts, set their jump addresses in                                                            |
|        |                   |                                       | (REIT instruction only) to                                                                  |
|        |                   |                                       | m from going wild when an                                                                   |
|        |                   | unused interrupt or                   |                                                                                             |

|                         | .LWORD<br>.LWORD<br>.LWORD<br>.LWORD<br>.LWORD<br>.LWORD<br>.LWORD<br>.LWORD           | dummy<br>dummy<br>dummy<br>dummy<br>dummy<br>dummy<br>dummy          | ; Timer B5 interrupt vector.<br>; UART2 transfer / NACK interrupt vector.<br>; UART2 receive / ACK interrupt vector.<br>; UART3 transfer / NACK interrupt vector.<br>; UART3 receive / ACK interrupt vector.<br>; UART4 transfer / NACK interrupt vector.<br>; UART4 receive / ACK interrupt vector.<br>; Bus collision detection / start,stop<br>; Condition(UART 2) interrupt vector. |
|-------------------------|----------------------------------------------------------------------------------------|----------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                         | .LWORD                                                                                 | dummy                                                                | ; Bus collision detection / start,stop<br>; Condition(UART 3) interrupt vector.                                                                                                                                                                                                                                                                                                         |
|                         | .LWORD                                                                                 | dummy                                                                | ; Bus collision detection / start,stop<br>; Condition(UART 4) interrupt vector.                                                                                                                                                                                                                                                                                                         |
|                         | .LWORD                                                                                 | dummy                                                                | ; A-D interrupt vector.                                                                                                                                                                                                                                                                                                                                                                 |
|                         | .LWORD                                                                                 | dummy                                                                | ; Key- input interrupt vector.                                                                                                                                                                                                                                                                                                                                                          |
| ,<br>- ******<br>,<br>, | .SECTION<br>.ORG                                                                       | Setting fixed vectors ****<br>F_VECT,ROMDATA<br>FIXED_VECT_TOP       | ******                                                                                                                                                                                                                                                                                                                                                                                  |
| ;;                      | .LWORD<br>.LWORD<br>.LWORD<br>.LWORD<br>.LWORD<br>.LWORD<br>.LWORD<br>.LWORD<br>.LWORD | dummy<br>dummy<br>dummy<br>dummy<br>dummy<br>dummy<br>dummy<br>START | ;Undefined instruction interrupt vector<br>;Overflow (INTO instruction) interrupt vector.<br>;BRK instruction interrupt vector.<br>;Address match interrupt vector<br>;Unused<br>;Watchdog timer interrupt vector<br>;Unused<br>;NMI interrupt vector<br>;Sets Reset vector                                                                                                             |
|                         | .END                                                                                   |                                                                      |                                                                                                                                                                                                                                                                                                                                                                                         |
|                         |                                                                                        |                                                                      |                                                                                                                                                                                                                                                                                                                                                                                         |

#### Figure 4.3.4 Sample program 3(Using interrupt)



## 4.3.7 ISP and USP

The M16C/80 series has two stack pointers: an interrupt stack pointer (ISP) and a user stack pointer (USP). Use of these stack pointers is selected by the U flag.

 (1) ISP is used when U = 0 Registers are saved and restored to and from the address indicated by ISP.
 (2) USP is used when U = 1

Registers are saved and restored to and from the address indicated by USP.

Use the ISP when programming in assembly language (not using high-level languages or OS). Although the USP may be used, caution is required when using peripheral I/O interrupts. For details, refer to "Relationship between software interrupt numbers and stack pointers" in the next page.

#### Regarding assignments of software interrupt numbers

The M16C/80 series has software interrupt numbers from 0 to 63. Numbers 8 through 43 are reserved for peripheral I/O interrupts(note 1). Therefore, remaining numbers 0 through 7 and 44 through 63 can be assigned software interrupts (INT instructions(note 2)). However, for the purpose of application, software interrupt numbers 32 through 63 are assigned to software interrupts used by the OS, etc. (numbers 48 through 63 used by M16C/80 real-time monitor (MR308), for example). When using an OS in your system, use software interrupt numbers 0 through 7 only.



Note 1: This varies with the type of microcomputer used. Please consult the user's manual supplied with your microcomputer. Note 2: The program branches to the address that is stored in the interrupt number specified by the INT instruction operand.



#### Relationship between software interrupt numbers and stack pointers

- (1) When a peripheral I/O interrupt or an INT instruction interrupt using software interrupt numbers 0 through 31 occurs
  - (a) The CPU reads address 000000H to get interrupt information (interrupt number, interrupt request level) and then clears the interrupt request bit for the accepted interrupt to 0.
  - (b) The FLG register content is saved to the CPU's internal temporary register.
  - (c) Flags U, I, and D of the FLG register are cleared.
    - Thus, by operation in (c)...
      - (i) The stack pointer is forcibly made the interrupt stack pointer (ISP).
      - (ii)Multiple interrupts are disabled.
      - (iii) Debug mode is cleared (not single-stepped).
  - (d) The CPU's internal temporary register (to which FLG has been saved) and PC register contents are saved to the stack area.
  - (e) The interrupt priority level of the accepted interrupt is set in the processor Interrupt Priority Level (IPL).
  - (f) The address written in the interrupt vector is transferred to the PC register.

<Stack status after accepting interrupt request>



<FLG status after accepting interrupt request>



Figure 4.3.6 When a peripheral I/O interrupt or an INT instruction interrupt using software interrupt numbers 0 through 31 occurs


Note: When not using the OS, software interrupts can be assigned numbers 32 through 63. In this case, stack pointer setup requires caution.

# 4.3.8 Multiple Interrupts

In the M16C/80 series, once an interrupt request is accepted, the interrupt enable flag (I) is automatically cleared to 0 (interrupts disabled), so that no other interrupts are accepted until processing of the accepted interrupt is completed. Therefore, if another interrupt needs to be generated while an interrupt is being serviced, this can be accomplished by setting the interrupt enable flag (I) to 1 (interrupts enabled) in the interrupt handling routine.

### **Example of Multiple Interrupt Execution**

As an execution example for multiple interrupts, or interrupts generated while an interrupt being serviced, an execution flow is shown in Figure 4.3.8 where multiple interrupts (1), (2), and (3) occur.

- (1) Interrupt 1 occurs when executing the main routine
- (2) Interrupt 2 occurs when executing interrupt 1
- (3) Interrupt 3 occurs when executing interrupt 2



# 4.3.9 High-speed interrupts

High-speed interrupts refer to an interrupt for which the interrupt acknowledgment (interrupt handling sequence) can be executed in 5 cycles and return from which can be executed in 3 cycles. High-speed interrupts are handled in such a way that when an interrupt is accepted, the flag register (FLG) and program counter (PC) respectively are saved to the CPU's internal registers, Save Flag Register (SVF) and Save PC Register (SVP), and the program is executed from the address indicated by the Vector Register (VCT).

High-speed interrupts become usable by setting the fast interrupt specification bit<sup>(Note 1)</sup> to 1, and the interrupt<sup>(Note 2)</sup> for which the software interrupt priority level has been set to 7 is handled as a fast interrupt. The diagram below shows how a fast interrupt operates.

### High-speed interrupt acknowledgment/return operations



Note 1: This bit is assigned to bit 3 of the Return Priority Register.

Note 2: Because only one interrupt at a time can be set as a fast interrupt, make sure there is only one interrupt whose interrupt priority level = 7.

Note 3: In this case, register bank 1 cannot be used in the main routine. Note 4: Execute the FREIT instruction to return from the fast interrupt routine.



### Program description example when using high-speed interrupts





| mmy:    | ===== D |                                |                                        |                                   |
|---------|---------|--------------------------------|----------------------------------------|-----------------------------------|
|         | REIT    |                                |                                        |                                   |
| ******* | *****   |                                | *****                                  |                                   |
|         | 5       | etting variable vector table " | ***************                        |                                   |
|         | SECTION | VECT, ROMDATA                  |                                        |                                   |
|         | ORG     | VECT_TOP                       |                                        |                                   |
|         |         |                                |                                        |                                   |
|         | LWORD   | dummy                          | ; BRK instruction interrupt vector     |                                   |
|         | ORG     | VECT TOP + (8 * 4 )            |                                        |                                   |
|         | LWORD   | dummy                          | ; DMA0 interrupt vector.               |                                   |
|         | LWORD   | dummy                          | ; DMA1 interrupt vector.               |                                   |
|         | LWORD   | dummy                          | ; DMA2 interrupt vector.               |                                   |
|         | LWORD   | dummy                          | ; DMA3 interrupt vector.               |                                   |
|         | LWORD   | dummy                          | ; Timer A0 interrupt vector.           |                                   |
|         | LWORD   | dummy                          | ; Timer A1 interrupt vector.           |                                   |
|         | LWORD   | dummy                          | ; Timer A2 interrupt vector.           |                                   |
|         | LWORD   | dummy                          | ; Timer A3 interrupt vector.           |                                   |
|         | LWORD   | dummy                          | ; Timer A4 interrupt vector.           |                                   |
|         | LWORD   | dummy                          | ; UART 0 transfer interrupt vector.    |                                   |
|         | LWORD   | 2                              |                                        |                                   |
|         | LWORD   | dummy                          | ; UART 0 receive interrupt vector.     |                                   |
|         |         | dummy                          | ; UART 1 transfer interrupt vector.    |                                   |
|         | LWORD   | dummy                          | ; UART 1 receive interrupt vector.     |                                   |
|         | LWORD   | dummy                          | ; Timer B0 interrupt vector.           |                                   |
|         | LWORD   | dummy                          | ; Timer B1 interrupt vector.           |                                   |
|         | LWORD   | dummy                          | ; Timer B2 interrupt vector.           |                                   |
|         | LWORD   | dummy                          | ; Timer B3 interrupt vector.           | For the interrupt which has been  |
|         | LWORD   | dummy                          | ; Timer B4 interrupt vector.           | set as a high-speed interrupt, do |
|         | LWORD   | dummy                          | , INT5 interrupt vector.               | not set the start address of the  |
|         | LWORD   | dummy                          | ; INT4 interrupt vector.               | interrupt handler routine in the  |
|         | LWORD   | dummy                          | ; INT3 interrupt vector.               | variable interrupt vector.        |
|         | LWORD   | dummy                          | ; INT2 interrupt vector.               |                                   |
|         | LWORD   | dummy                          | ; INT1 interrupt vector.               |                                   |
|         | LWORD   | dummy                          | ; INT0 interrupt vector.               |                                   |
|         | LWORD   | dummy                          | ; Timer B5 interrupt vector.           |                                   |
|         | LWORD   | dummy                          | ; UART2 transfer / NACK interrupt      |                                   |
|         | LWORD   | dummy                          | ; UART2 receive / ACK interrupt v      |                                   |
|         | LWORD   | dummy                          | ; UART3 transfer / NACK interrupt      |                                   |
|         | LWORD   | dummy                          | ; UART3 receive / ACK interrupt v      |                                   |
|         | LWORD   | dummy                          | ; UART4 transfer / NACK interrupt      |                                   |
|         | LWORD   | dummy                          | ; UART4 receive / ACK interrupt v      |                                   |
|         | LWORD   | dummy                          | ; Bus collision detection / start,stop |                                   |
|         |         |                                | ; Condition(UART 2) interrupt vect     |                                   |
|         | LWORD   | dummy                          | ; Bus collision detection / start,stop |                                   |
|         |         |                                | ; Condition(UART 3) interrupt vect     |                                   |
|         | LWORD   | dummy                          | ; Bus collision detection / start,stop |                                   |
|         |         |                                | ; Condition(UART 4) interrupt vect     | or.                               |
|         | LWORD   | dummy                          | ; A-D interrupt vector.                |                                   |
|         | LWORD   | dummy                          | ; Key- input interrupt vector.         |                                   |

| .SE<br>.OF | CTION<br>RG | F_VECT,ROMDATA<br>FIXED_VECT_TOP |                                               |
|------------|-------------|----------------------------------|-----------------------------------------------|
| .LV        | /ORD        | dummy                            | ;Undefined instruction interrupt vector       |
| .LV        | /ORD        | dummy                            | ;Overflow (INTO instruction) interrupt vector |
| .LV        | /ORD        | dummy                            | ;BRK instruction interrupt vector.            |
| .LV        | /ORD        | dummy                            | ;Address match interrupt vector               |
| .LV        | /ORD        | dummy                            | ;Unused                                       |
|            | /ORD        | dummy                            | ;Watchdog timer interrupt vector              |
|            | /ORD        | dummy                            | ;Unused                                       |
|            | /ORD        | dummy                            | ;NMI interrupt vector                         |
| .LV        | /ORD        | START                            | ;Sets Reset vector                            |
| .EN        | ID          |                                  |                                               |



# 4.4 Dividing Source File

Write the program separately in several source files. This helps to make your program put in order and easily readable. Furthermore, since the program can be assembled separately one file at a time, it is possible to reduce the assemble time when correcting the program. This section explains how to divide the source file.

### 4.4.1 Concept of Sections

A program written in the assembly language generally consists of a work area, program area, and constant data area. When the source file (\*\*\*.AS30) is assembled by the assembler (as308), relocatable module files (\*\*\*.R30) are generated. The relocatable module files contain one or more of these areas. A section is the name that is assigned to each of these areas. Consequently, a section can be considered to be the name that is assigned to each constituent element of the program. Note that the assembler (as308) requires that even in the case of the absolute file, there must always be at least one section specified in one file.



## **Functions of Sections**

When linking the source files, the areas of the same section name are located at contiguous addresses sequentially in order of specified files. Furthermore, the start address of each section can be specified when linking. This means that each section can be relocated any number of times without having to change the source program. Figure 4.4.1 shows an example of how sections actually are located in memory.



### 4.4.2 Example of program description in divided files

The as308 used in this manual is a relocatable assembler. When using a relocatable assembler, it is normally desirable to write the program source separately in several files. The following lists the advantages that can be obtained by dividing the source file:

#### (1) Shared program and data

Data exchanges between development projects are facilitated, making it possible to reuse only a necessary part from existing software.

#### (2) Reduced assemble time

When modifying or correcting the program, only the modified or corrected file needs to be reasssembled. This helps to reduce the assemble time.

The following explains how to write the source program in cases when the file is divided into three (definition, main program, and subroutine processing).



# Division Example 1: Definition (WORK.A30)

| •*************************************                                             | File 1 (WORK.A30)                                                                                                       |                                                                                                   |
|------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|
| .SECTION<br>.ORG                                                                   | be referen                                                                                                              | or work RAM and labels to need from another file, lobal labels using .GLB.                        |
| .GLB<br>.GLB<br>.BTGLBW1_b0                                                        | WORK_1,WORK_2,WORK_3,WÓRK_4<br>DATA_TABLE<br>J,W2_b1                                                                    | ; Processed as global label.<br>; Processed as global label.<br>; Processed as global bit symbol. |
| ,<br>GLOBAL_WORK_TOP<br>WORK_1:<br>WORK_2:<br>WORK_3:<br>WORK_4:<br>GLOPA_WORK_END | .BLKB 1 BTEQU to be referenced from<br>.BLKB 1 another file, declare global symbols<br>.BLKB 1 using .BTGLB.<br>.BLKB 1 | ; Allocates work RAM area.                                                                        |
| GLOBAL_WORK_END<br>W1_b0 .BTEQ<br>W2_b1 .BTEQ<br>:<br>:                            | U 0,WORK_1                                                                                                              | ; Defines bit symbols.<br>;                                                                       |
| .SECTION<br>.ORG                                                                   | CONSTANT,ROMDATA<br>CONST_TOP                                                                                           |                                                                                                   |
| DATA_TABLE:<br>.BYTE<br>.BYTE<br>.BYTE<br>.BYTE                                    | 34H<br>56H                                                                                                              | ; Sets 1-byte data.                                                                               |
| DATA_TABLE_END:<br>;<br>.END                                                       |                                                                                                                         |                                                                                                   |



### Division Example 2: Main Program (MAIN.A30)





### Division Example 3: Subroutine Processing (SUB\_1.A30)

Write subroutine processing("PROGRAM" section) and allocated work RAM area("WORK" section) in file 3.

| ****** | *****                    | File 3 (SUB_1.A30)       | ******       | *****                                                                                                 |
|--------|--------------------------|--------------------------|--------------|-------------------------------------------------------------------------------------------------------|
| ****** | ·**************** A      | Ilocation of work RAM a  | rea******    | *****                                                                                                 |
|        | .SECTION                 | WORK,DATA                |              | ss declared as global, labels are handled cal labels in file 3 (SUB_1.A30).                           |
|        | _WORK_TOP:               | .BLKB 1                  |              | : Allocates area for local data.                                                                      |
|        |                          | .BLKB 1                  |              | , Allocales area for local data.                                                                      |
|        | <br>WORK END:            | .DLND I                  | / Si         | nce subroutine (SUB_1) is called from file 2                                                          |
|        |                          |                          |              | IAIN.A30), specify SUB_1 to be a global label                                                         |
| ****** | ********************** D | eclaration to assembler* |              | sing .GLB before call. (Because the label exists                                                      |
|        | _                        |                          | //  in       | the file, this becomes a global declaration.)                                                         |
|        | .SECTION                 | PROGRAM,CODE             | / _          |                                                                                                       |
|        | .GLB                     | SUB_1                    |              | ; Processed as global label.                                                                          |
|        | .GLB                     | DATA_TABLE               |              | ; Processed as external reference label.                                                              |
|        | 00                       | 0000011                  |              |                                                                                                       |
|        | .SB<br>.FB               | 00380H<br>00480H         |              | ; Sets SB register value for assembler.                                                               |
|        | .SBSYM                   | LOCAL_1,LOCAL_2          |              | ; En des specified label in SR relative addressing mode                                               |
|        |                          | == Program area =====    |              | Because a label present in another file (file 1) is                                                   |
| SUB_1  |                          |                          | $\mathbf{V}$ | used in the program, it is specified to be externally                                                 |
| _      | LDC                      | #380H,SB                 | N            | ; Sets ir referenced.                                                                                 |
|        | LDC                      | #480H,FB                 | $\mathbb{N}$ | ; Sets initial value in FB register.                                                                  |
| ;      |                          |                          |              | -                                                                                                     |
|        | MOV.B                    | #05H,LOCAL_1             |              | ; Accesses local data (LOCAL_1) in SB relative addressing.                                            |
|        |                          | <b>110.00</b>            | //           |                                                                                                       |
|        | MOV.W                    |                          | · · · //     | Detrieves fixed data table by automal references                                                      |
|        | MOV.B                    | DATA_TABLE[A0],LOC       | JAL_2 \'     | ; Retrieves fixed data table by external reference.                                                   |
|        | ADD.B                    | LOCAL_1,LOCAL_2          | \            | Adds local data (LOCAL_1, LOCAL_2).                                                                   |
|        | •                        |                          |              |                                                                                                       |
|        | •                        |                          |              | Because of a relative attribute section, the label                                                    |
|        | RTS                      |                          |              | address remains pending until linked and code                                                         |
|        |                          |                          |              | generation is not optimized for SB relative                                                           |
|        | .END                     |                          |              | addressing mode. Therefore, it is forcibly encoded<br>in SB register relative addressing by ".SBSYM." |
|        |                          |                          |              | III OD TEGISLET TETALIVE AUDIESSING DY .ODOTM.                                                        |



### Making Use of Include File

Normally, write part of external reference specification of symbols and bit symbols (those defined with .EQU, .BTEQU) and/or labels (those having address information) in one include file. In this way, without having to specify external reference in each source file, it is possible to externally reference symbols and labels by reading include files into the source file.





### Making Use of Directive Command .LIST

By writing directive commands ".LIST ON" and ".LIST OFF" at the beginning and end of an include file, it is possible to inhibit the include file from being output to an assembler list file. Figure 4.4.6 shows examples of assembler list files, one not using these directive commands (expansion 1) and one using them (expansion 2).



# 4.4.3 Using library files

A library file refers to a collection of several relocatable module files. If there are frequently used modules, collect them in a single library file using the librarian (lib308) that is included with the AS308 system. When linking source files, specify this library file (\*\*\*.LIB). By so doing, only the necessary modules (those specified in the file as externally referenced) can be extracted when linking. This makes it possible to reduce the assemble time and reuse the program. The following shows an example of how a library file is created and how it is linked.

### **Creating Library File**





# **Example for Linking Library Files**



# 4.5 A Little Tips...(Programing technique)

This section provides some information, knowledge of which should prove helpful when using the M16C/80 series. This information is provided for several important topics, so refer to the items in interest.

# 4.5.1 Setup Values of SB and FB Registers

The following explains the setup values of the SB and FB registers.

### Basic method for using SB and FB registers

Use the SB and FB registers to set the start address of an area that contains frequently accessed data. Specifically, using these registers to set the frequently used SFR area and work RAM area may prove effective.

Figure 4.5.1 shows an example for setting the SB and FB registers when using them as having fixed values.



### Application for using SB and FB registers differently

ENESAS

When using the SB and FB registers after setting them to have fixed values in the program, the address range in which efficient access can be expected is limited to a maximum of 256 bytes each, for a total of 512 bytes.

If use of SB/FB relative addressing over a greater range is desired in order to increase the efficiency of accessing work data or ROM efficiency, the objective may be accomplished by changing the values set in the SB and FB registers "for each subroutine called", in other words by using the registers dynamically.

For an example of how to use, refer to Figure 4.5.3, "Program example for using SB and FB registers dynamically."





# Programming example when using SB and FB registers dynamically

|                         | ====== {                                                                         | Start up =========                                       |                |                                                                                                                                                                                                                        |
|-------------------------|----------------------------------------------------------------------------------|----------------------------------------------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| .SECT<br>.ORG<br>START: |                                                                                  | ROGRAM,CODE<br>COM_TOP                                   |                | ; Declares secyion name and section type.<br>; Declares start address.                                                                                                                                                 |
|                         | LDC #                                                                            | RAM_END+1,ISP                                            |                | ; Sets initial value of stack pointer (SP).                                                                                                                                                                            |
|                         | Always be sure to set the<br>values in the assembler a<br>those set in SB and FB |                                                          | er as          |                                                                                                                                                                                                                        |
| .SB<br>.FB              |                                                                                  | registers.<br>340H,SB<br>4C0H,FB                         |                | ; Declares SB register value to the assembler.<br>; Declares FB register value to the assembler.<br>; Sets initial value for SB register.<br>; Sets initial value for SB register.                                     |
|                         | =====Ma                                                                          | ain program =======                                      | progra<br>340H | itial values for the SB and FB registers. In the sample<br>am, SB relative addressing can be used in the range of<br>to 43FH, and FB relative addressing in the range of 44<br>53FH, by the main and the INIT routine. |
| IAIN:                   | JSR<br>FSET                                                                      | INIT<br>I                                                |                | ; Initialization routine<br>; Enable interrupts                                                                                                                                                                        |
| 1AIN_10:                | JSR                                                                              | SUB_1                                                    |                | ;Calls subroutine "SUB_1"                                                                                                                                                                                              |
|                         | JSR                                                                              | SUB_2                                                    |                | ; Calls subroutine "SUB_2"                                                                                                                                                                                             |
|                         | JMP                                                                              | MAIN_10                                                  |                |                                                                                                                                                                                                                        |
| <br>NIT:                | MOV.B #                                                                          | IIT routine ====================================         |                |                                                                                                                                                                                                                        |
|                         | MOV.W#                                                                           | 01000000B,TA0MR<br>2500-1,TA0<br>00000111B,TA0IC<br>TA0S |                | ; Sets timer A0 mode register.<br>; Sets timer A0 count value.<br>; Sets timer A0 interrupt priority level.<br>; Timer A0 starts counting.                                                                             |



|                                                        | SUB_1                              | changed wit                                                                             | sure to specify the values to be<br>ith ".SB" and ".FB" in the<br>too.                                                                                                                                                                                                                        |
|--------------------------------------------------------|------------------------------------|-----------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SUB_1:                                                 | .SB 400H<br>.FB 580H<br>LDC<br>LDC | #400H,SB<br>#580H,FB                                                                    | ; Declares SB register value to be changed the assembler.<br>; Declares SB register value to be changed the assembler.<br>; Changes SB register value.<br>; Changes FB register value.                                                                                                        |
| ;<br>;<br>;<br>SUB_1_END:                              | MOV.B<br>INC.B<br>RTS              | WORK_1,R0L<br>R0L                                                                       | Set the SB and FB register values according to the range<br>of SB and FB relative addressing to be used in the<br>subroutine "SUB_1."<br>Note: Always be sure to set the SB and FB register<br>values before accessing the work RAM, etc. (Normally<br>set at the beginning of each routine.) |
| ;<br>SUB_2:                                            |                                    | routine ====================================                                            | ; Declares SB register value to be changed the assembler.<br>; Declares FB register value to be changed the assembler.<br>; Changes SB register value.<br>; Changes FB register value.                                                                                                        |
| ;                                                      | MOV.B<br>DEC.B                     | WORK_2,R1L<br>R1L<br>Because interrupts                                                 | Set the SB and FB register values according to the<br>range of SB and FB relative addressing to be used in<br>the subroutine "SUB_2."<br>Note: Always be sure to set the SB and FB register<br>values before accessing the work RAM, etc. (Normally<br>set at the beginning of each routine.) |
| SUB_2_END:<br>;<br>;================================== | RTS                                | asynchronously, alw<br>save the SB and FE<br>values used by the<br>before setting value | ways be sure to<br>B register<br>main routine                                                                                                                                                                                                                                                 |
| ;                                                      | .SB 1000H<br>FSET<br>LDC           | B<br>#1000H,SB                                                                          | ; Declares SB register value to be changed the assembler.<br><u>: Saves registers( includeing SB</u> and FB registers)<br><u>; Changes SB register value.</u>                                                                                                                                 |
| ;                                                      | MOV.B<br>DADD.B                    | #0, COUNT<br>#2, DATA                                                                   | Set the SB and FB register values according to<br>the range of SB and FB relative addressing to be<br>used in the interrupt handler "INT_TA0."                                                                                                                                                |
| ,<br>INT_TAO_END<br>;<br>;                             | REIT                               |                                                                                         |                                                                                                                                                                                                                                                                                               |
| igure 4.5.3                                            | .END<br>Program ex                 | kample for usin                                                                         | ng SB and FB registers dynamically                                                                                                                                                                                                                                                            |

# 4.5.2 Specifying ROM/RAM data alignments

This section explains how to specify data alignments.

### About data alignments

This refers to address adjustment so that when the directive command ".ALIGN" is written, the code in the immediately following line is stored in an even address. For section types "CODE" or "ROMDATA," NOT instructions are written in locations that have been left blank as a result of address adjustment. For section type "DATA," addresses are only adjusted, leaving blank locations intact. If the location where this directive command is written happens to be an even address, no address adjustment is performed.

This directive command can be written in a section that falls under the following conditions:

#### (1) Relative attribute section for which address adjustment is specified in section definition

.SECTION WORK, DATA, <u>ALIGN</u>

(2) Absolute attribute section (no specific limitations)

.SECTION WORK, DATA .ORG 400H



### Advantages of Alignment Specification (Correction to Even Address)

If data of different sizes such as a data table are located at contiguous addresses, the data next to an odd size of data is located at an odd address. In the M16C/80 series, word data (2-byte data) beginning with an even address is read/written in one access, those beginning with an odd address requires two accesses for read/write. Consequently, for data in size of 2 bytes or more such as words and long words, access efficiency and instruction execution speed can be increased by locating data at even addresses. In this case, however, ROM (or RAM) efficiency decreases. Figure 4.5.4 shows an example of a program description that contains alignment specification.

#### (1) For relative attribute sections

|       |           |                       | Address         | Code                                     |
|-------|-----------|-----------------------|-----------------|------------------------------------------|
| [     | .SECTION  | WORK, DATA, ALIGN     |                 |                                          |
| WORK  | (_1 .BLKW | 1                     | 00000H          |                                          |
| WORK  | (_2 .BLKW | 1                     | 0002H           |                                          |
| WORK  | (_3 .BLKB | 1                     | 0\004H          |                                          |
|       | .ALIGN    |                       | 00 <u>\</u> 05⊢ | Address is incremented by 1.             |
| ;     |           |                       |                 |                                          |
|       | •         |                       | Se              | t data tables and similar other sections |
|       | •         |                       | Jat             | even addresses as much as possible.      |
| L     | .SECTION  | CONST, ROMDATA, ALIGN |                 |                                          |
| .BYTĘ | 12H       |                       | 00000H          | 12H                                      |
|       | .ALIGN    |                       | 00001H          | 04H NOP code is inserted.                |
| .WORI | D 3456H   |                       | 00002H          | 5634H                                    |
|       | •         |                       |                 |                                          |
|       | •         |                       |                 |                                          |
|       |           |                       |                 |                                          |

#### (2) For absolute attribute sections

|                                |                                         | Address     | Cod                                                 | e                 |
|--------------------------------|-----------------------------------------|-------------|-----------------------------------------------------|-------------------|
| .SECTIO<br>.ORG<br>WORK 1.BLKB | N WORK, DATA<br>400H                    |             | nd similar other sections<br>s as much as possible. |                   |
| ALIGN                          |                                         | 00400H      | Address is                                          | incremented by 1. |
| WORK_2 .BLKW                   |                                         | 00402H      |                                                     |                   |
| WORK_3 .BLKA                   | 1                                       | 00404H      |                                                     |                   |
| .ALIGN                         |                                         | 00407H      | Address is                                          | incremented by 1. |
| WORK_4 .BLKL                   | 1                                       | 00408H      |                                                     |                   |
| ;<br>.ORG<br>MOV.W #           | N PROGRAM,CODE<br>0F0000H<br>¢0,R0<br>• | Е<br>F0000H | D900H                                               | 7                 |

#### Figure 4.5.4 Example of alignment specification



# 4.5.3 Setting stack pointer

The following explains how to set up stack pointers and how to save and restore to and from the stack area when using an interrupt and a subroutine.

### Setting Up Stack Pointers (ISP or USP)

| (1) Choosing the stack pointer ( | ISP or USP) to use |
|----------------------------------|--------------------|
|----------------------------------|--------------------|

When developing a program in only assembly language, normally use the ISP. When using both ISP and USP, set the initial value of the U flag to 1 (the USP used). As a result, the stack area identified by "USP" is used on the main routine side, while the stack area identified by "ISP" is used by the peripheral I/O interrupt handler routine(note 1). This allows the amounts of stack used to be estimated separately for main processing and interrupt handling. This should prove effective when jointly developing a program by separating it into files between two or more people. For details, refer to Section 4.3.7, "ISP and USP."

#### (2) Set the initial value in the selected stack pointer register.

Because the stack in the M16C/80 group is FILO type<sup>(Note 2)</sup>, it is recommended that the stack pointer initial value be set at the last address of the RAM area. Also, when registers are saved and restored to and from the stack, the stack pointer changes by 2 at a time when either increased or decreased Therefore, make sure the initial value is always set at an even address. For details, refer to "Saving and restoring to and from the stack" in the next page.

Set up example: When setting "2C00H" for the interrupt stack pointer (SIP) and "2900H" for the user stack pointer (USP)  $^{(Note \ 3)}$ 

| ; |             | -Initializing stack po | pinters                                                                               |
|---|-------------|------------------------|---------------------------------------------------------------------------------------|
| , | LDC<br>FSET | #002C00H,ISP<br>U      | ; Sets "2C00H" for ISP.                                                               |
|   | LDC         | #002900H,SP            | ; Sets "2900H" for USP.                                                               |
|   | FCLR        | U                      | ; Uses USP on the main side,<br>; and uses ISP on the interrupt handler routine side. |
| ; |             |                        |                                                                                       |

Note 3: Because ISP, USP, and FLG are dedicated registers, use the LDC and FSET/FCLR instructions to set these registers.

Note 1: When using both ISP and USP, be careful not to locate one stack area overlapping the other when allocating memory for the stack. Also, be sure to set values for both stack pointers.

Note 2: FILO (First In, Last Out): When saving registers, they are stacked one on top of another in order of addresses, from large address toward smaller addresses. When restoring registers, they are removed from the stack in the direction toward larger addresses beginning with the last register saved.



### Saving and restoring to and from the stack

Registers, etc. are saved and restored to and from the stack in the following cases:

#### (1) When an interrupt is accepted

When an interrupt is accepted, the registers shown below are saved to the stack area:

#### Program Counter (PC) -> 4 bytes (The most significant byte is fixed to 00H.) Flag Register (FLG) -> 2 bytes ... 6 bytes in total

However, if the accepted interrupt is a fast interrupt, the Flag Register (FLG) and Program Counter (PC) respectively are saved to the Save Flag Register (SVF) and Save PC Register (SVP), with nothing placed in the stack.

After interrupt handling is finished, the above saved registers are restored from the stack area by the REIT instruction.



Note: Even when one byte of data are saved/restored using push and pop instructions (e.g., PUSH, POP, PUSHM, and POPM), the stack pointer always changes by 2 at a time.

(2) When calling a subroutine (when executing JSR, JSRI, or JSRS instruction) When the JSR, JSRI, or JSRS instruction is executed, the register shown below is saved to the stack area:

### Program Counter (PC) -> 4 bytes (The most significant byte is fixed to 00H.)

When the subroutine is completed, the above saved register is restored from the stack area by the RTS instruction.



# 4.5.4 Using special pages

The M16C/80 series has a reserved area in the fixed vectors that is called the "special page vector table," with each vector assigned a special page number. (Refer to Section 2.1.3, "Fixed Vector Area.") This vector table can be used to store subroutine or jump addresses, and by specifying a special page number in the special page subroutine call instruction (JSRS) or special page jump instruction (JMPS), it is possible to branch off in fewer bytes than possible with the ordinary subroutine call instruction (JSR) or jump instruction (JMP)<sup>(Note)</sup>.

As a result, the number of program steps and the ROM size can be reduced.

# Example for using a special page



Note: If the branch distance specifier ".S" or ".B" is used, code size is smaller for ordinary jump instructions than for special page jump.





### 4.5.5 Example for using software interrupt (INTO instruction)

The INTO instruction (overflow interrupt) is a software interrupt instruction that generates an interrupt when it is executed while the Flag Register (FLG)'s overflow flag (O) is set to 1.

Therefore, the INTO instruction can be used to call an overflow handling routine when the operation of a divide instruction (e.g., DIV, DIVU) or multiply/accumulate instruction (RMPA) resulted in an overflow. Figure 4.5.8 shows an example of how to use the INTO instruction.

### Example for using the INTO instruction

| <br>/AIN:      |              | program =========    |                                                 |
|----------------|--------------|----------------------|-------------------------------------------------|
| VIAIN.         | JSR          | INIT                 | : Initialization routine                        |
| MAIN 10:       | oon          |                      |                                                 |
| ··· ··· _ · •· | MOV.L        | DATA1, R2R0          |                                                 |
|                | DIV.W        | #5                   | ; Signed divide                                 |
|                | INTO         |                      | ; Overflow interrupt                            |
|                | MOV.W        | R0, ANS_DAT1         |                                                 |
|                | _            |                      | Only when the operation resulted in an overflow |
|                | •            |                      | (O flag = 1), an interrupt is generated by the  |
|                |              |                      | INTO instruction; otherwise, no interrupt is    |
|                | MOV.L        | #0, R2R0             | generated and the next instruction is executed. |
|                | MOV.W        | #0, R1               |                                                 |
|                |              |                      |                                                 |
|                | MOV.L        | #10000H, A0          | ; Sets address in which to sore multiplicand.   |
|                | MOV.L        | #20000H, A1          | ; Sets address in which to store multiplier.    |
|                | MOV.W        | #0FFH, R3            | ; Sets number of times products are summed,     |
|                | RMPA.W       |                      | ; Perform multiply / accumulate operation       |
| L              | INTO         |                      | ; Overflow interrupt                            |
|                |              |                      |                                                 |
|                | MOV.L        | R2R0, ANS_DAT2       | When an overflow occurs during the multiply/    |
|                | MOV.W        | R1, ANS_DAT2+4       | accumulate operation (O flag = 1), the          |
|                |              |                      | instruction being executed is suspended and     |
|                |              |                      | the next instruction (INTO instruction) is      |
|                | •            |                      | executed, so that an interrupt is generated by  |
|                | JMP          | MAIN_10              | the INTO instruction.                           |
|                |              |                      |                                                 |
| ,              | ====== INI I | routine ============ |                                                 |
| INIT:          | MOV.W        | #0FFFFH, DATA1       |                                                 |
|                | MOV.W        | #0, ANS DAT1         |                                                 |
|                |              | #0, ANS_DATT         |                                                 |
|                |              |                      |                                                 |
|                |              |                      |                                                 |
|                | •            |                      |                                                 |
| NIT_END:       | DTO          |                      |                                                 |
|                | RTS          |                      |                                                 |



|       | Processing p       | erformed when the operation resulted | l in an overflow                                    |
|-------|--------------------|--------------------------------------|-----------------------------------------------------|
|       | VER FLOW E         |                                      |                                                     |
| NI_C  | REIT               |                                      |                                                     |
|       |                    |                                      |                                                     |
|       |                    |                                      |                                                     |
|       |                    | == Dummy interrupt program ======    |                                                     |
| umm   |                    |                                      |                                                     |
|       | REIT               |                                      |                                                     |
|       |                    |                                      |                                                     |
| ***** | ***** Setting fixe | ed vector *********** Notice         | e that the vector for the overflow                  |
|       | Cotting int        |                                      | upt (INTO instruction) is a fixed vector.           |
|       | .SECTION           | F_VECT,ROMDATA                       |                                                     |
|       | .ORG               | 0FFFFDCH //                          | ; Start address of fixed interrupt vector           |
|       | .LWORD             | dummy                                | ; Undefined instruction interrupt vector            |
|       | .LWORD             | INT_OVER_FLOW                        | ; Sets start address of interrupt handler           |
|       |                    |                                      | ; for Overflow( INT O instruction) interrupt vector |
|       | LWORD              | dummy                                | ; BRK instruction interrupt vector                  |
|       | .LWORD<br>.LWORD   | dummy<br>dummy                       | ; Address match interrupt vector<br>: Unused        |
|       | LWORD              | dummy                                | ; Watchdog timer interrupt vector                   |
|       | LWORD              | dummy                                | : Unused                                            |
|       | LWORD              | dummy                                | ; NMI interrupt vector                              |
|       | LWORD              | START                                | ; Sets reset vector                                 |
|       |                    |                                      |                                                     |



This section explains how to prevent the program from going wild by means of software, for example, using a watchdog timer or software interrupt instruction.

### Using a watchdog timer

**CENESAS** 

The watchdog timer is a 15-bit timer, which is used to detect occurrence of program runaway. When the program goes wild, the watchdog timer under-flows, generating an interrupt. The program can be restarted in this watchdog timer interrupt handling by, for example, a software reset.

The watchdog timer interrupt is non-maskable. After a reset, the watchdog timer remains idle, and is made to start counting by a write to the watchdog timer start register. Note that the watchdog timer is initialized when the CPU is reset, when data is written to the watchdog timer start register, and when a watchdog timer interrupt request is generated.

### Method for Detecting Program Runaway

The chart below shows an operation flow when the program is found out of control and the method of runaway detection.

#### (1) Operation flow



#### Figure 4.5.9 Operation flow when program runaway is detected

### (2) Method of runaway detection

Program a procedure so that a write to the watchdog timer start register is performed before the watchdog timer under-flows. By writing to the watchdog timer start register, the initial count "7FFFH" is set in the watchdog timer. (This is fixed, and not other value can be set.) If this write operation is inserted in a number of locations, it can happen that a write to the watchdog timer start register is performed at a place to which the program has been brought by runaway. Thus, no where in the program can it be detected to have run out of control. Therefore, be careful that this write operation is inserted in only one location such as the main routine that is always executed. However, consider the length of the main routine and that of the interrupt handler routine to ensure that a write to the watchdog timer start register will be performed before a watchdog timer interrupt occurs.

#### (3) Restarting the program after having gone wild

Write your program so that Processor Mode Register 0 bit 3 (software reset bit) is set by writing a 1 in an interrupt handler routine. This generates a software reset, so the program restarts from its reset state. (The internal RAM contents retained at this time are those that were being held immediately before the reset.)

Make sure the start address of this interrupt handler routine is set in the interrupt vector for the watchdog timer interrupt beforehand.

When restarting the program from its reset state, always be sure to use the software reset bit to reset it. Note that if the address value that has been set in the interrupt vector for the watchdog timer interrupt is the same as that of the reset vector, the IPL (processor interrupt priority level) remains 7 without being cleared. Therefore, when the program restarts, a problem is encountered that all other interrupts are disabled.



### **Examples of Runaway Detection Programs**

Figures 4.5.10 and 4.5.11 show sample programs in which the watchdog timer is used to detect program runaway.

Example 1: Operation (subroutine) for writing to the watchdog timer start register is executed periodically at predetermined intervals



Figure 4.5.10 Example of runaway detection program 1

Example 2: Interrupt handling program to restart the system is executed when a watchdog timer interrupt occurs



Figure 4.5.11 Example of runaway detection program 2

Note 1: If the program runs out of control, the contents of the base registers (SB, FB) are not guaranteed. Therefore, they must be set correctly again before writing values to the SFR.

Note 2: The system enters a reset sequence immediately after the software reset bit is set to 1. Therefore, no instructions following it are executed.

### Using software interrupts (UND/BRK instructions)

Both BRK and UND instructions are software interrupt instructions that generate an interrupt when the instruction is executed. These instructions can also be used to detect occurrence of program runaway. The following shows how to detect.

### The method of detecting runaway

Program runaway detection can be accomplished by embedding the BRK or UND instruction in an area of ROM other than one being used as the program area beforehand. When the program goes wild and accesses an unused area of ROM, it fetches the UND or BRK instruction stored in the area, at which time an interrupt is generated, providing a means of detecting runaway. Also, by storing the start address of a dummy interrupt handler in an unused interrupt vector beforehand, it is possible to prevent the program from going wild in the event an unused interrupt occurs. For description examples, refer to Section 4.3.6, "Sample List 3 (Using Interrupts)." To restart the program that has gone wild and handle the generated interrupt, follow the same procedure as when using the watchdog timer that is described earlier.



# 4.5.7 Method for using the "-LOC" option

This section explains how to use the linker (LN308) option "-LOC" (specify section data location) that is included in the M16C/80 series assembler system.

### About the "-LOC" option

The "-LOC" option specifies the address at which to store the internal data of a specified section, and is used when modules need to be stored in other areas than the run-time storage area(note). Therefore, the internal label values (address values) of a specified section are generated with respect to the address specified by ".ORG" in the source file or the address specified by the linker option "-ORDER" when linking.

#### Usage example

Shown below is an example where the section name "PROGRAM" that is stored at address EF0000H is transferred to address 1000H before program execution, then the program is executed from address 1000H.



Note: This method may be used for the flash ROM version of the M16C/80 series where when writing a program to the internal flash ROM in CPU rewrite mode, the program used to write to the flash ROM is run in RAM.

# 4.6 Standard processing program

This section shows examples of commonly used processing in programming of the M16C/80 series. For more information, refer to Application Notes, "M16C/80 Series Sample Programs Collection".

# **Conditional Branching Based on Specified Bit Status**



### **Retrieving Data Table**





### Subroutine call by table jump




# Appendix

Command input form and command parameters in AS308 system

Appendix A. Generating Object Files A-1 Assembling (as308) A-2 Link (In308) A-3 Generating Machine Language File



# Appendix A Generating Object Files

The AS308 system is a program development support tool consisting of an assembler (as308), linkage editor (In308), load module converter (Imc308), and other tools (Ib308, abs308, and xrf308). This section explains how to generate object files using the AS308 system.



Figure A.1 Outline of processing by AS308

Note: In this manual, the AS308 system is referred to by "AS308 system" (uppercase) when it means the entire system or by "as308" (lowercase) when it means only the assembler (as308).



# Appendix A-1 Assembling (as308)

The following explains the files generated by the relocatable assembler (as308) and how to start up the assembler.

#### Files Generated by as308

- (1) Relocatable module file (\*\*\*.R30) ... Generated as necessary This file is based on IEEE-695. It contains machine language data and its relocation information.
- (2) Assembler list file (\*\*\*.LST) ... Generated when option '-L' is specified This file contains list lines, location information, object code, and line information. It is used to output these pieces of information to a printer.
- (3) Assembler error tag file (\*\*\*.TAG) ... Generated when option '-T' is specified This file contains error messages for errors that occurred when assembling the source file. This file is not generated when no occur was encountered. This file allows errors to be corrected easily when it is used an editor that has the tag jump function.



# Method for Starting Up as308

>as308 file name.extension [file name.extension...] [option]
Be sure to write at least one file name. The extension (.A30) can be omitted.

#### Table A.1 Command Options of as308

| Command option          | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                         | Inhibits assemble processing messages from being output.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| -A                      | Evaluates mnemonic operand.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| -abs16                  | Specifys 16-bit absolute addressing mode.<br>*Allways input this option in small letters.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| -C                      | Displays command options when as308 has started up mac308 and asp308.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
| -D symbol name=constant | Sets symbol constant.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
| -F expansion file name  | Fixes expansion file of directive commandFILE.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
| -H                      | Header information is not output to an assembler list file.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| -1                      | The include fille specified by ".INCLUDE" that is written in the source file is seaeched from a specified directory.                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
| -L                      | <ul> <li>-L The software generates an assembler list file.</li> <li>-LC Line concatenation is output directory as is to a list file.</li> <li>-LD Information before .DEFINE is replaced is output to a list file.</li> <li>-LI Even program sections in which condition assembler resulted in false conditions are output to the assembler list file.</li> <li>-LM Even macro description expansion sections are output to the assembler list file.</li> <li>-LS Even structured description for AS30 expansion sections are output to the assembler list file.</li> </ul> |  |  |
| -mod60                  | AS308 replaces some of the commands in the program written for AS30. *Always input this option in small letters.                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| -mod60p                 | Processes structured commands for AS30.<br>*Always input this option in small letters.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| -N                      | Inhibits line information of macro description from being output to relocatable module file.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| -O directory path name  | Specifies directory for file generated by assembler. Do not insert space between the letter O and directory name. (Default is current directory.)                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| -S                      | Outputs local symbol information to relocatable module file.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| -т                      | Generates tag file.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| -V                      | Displays version of assembler system each program.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
| -X program name         | Generates error tag file and invokes command.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |



# Example for Using as308 Commands



# **Assembler List File**



| .***********************                                                                                                      | Defined hit symbol ******                                                                                                                  | ****                                                                                                                                                                                        |
|-------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ,                                                                                                                             | ,                                                                                                                                          | ; Bit 0 of char                                                                                                                                                                             |
| short_b1                                                                                                                      | .BTEQU 1,shor                                                                                                                              |                                                                                                                                                                                             |
| addr_b2                                                                                                                       | .BTEQU 2,addi                                                                                                                              |                                                                                                                                                                                             |
| ;                                                                                                                             |                                                                                                                                            | ; Bit 3 of long                                                                                                                                                                             |
|                                                                                                                               |                                                                                                                                            |                                                                                                                                                                                             |
| .PAGE                                                                                                                         | ******                                                                                                                                     | *****                                                                                                                                                                                       |
|                                                                                                                               |                                                                                                                                            |                                                                                                                                                                                             |
| ,                                                                                                                             |                                                                                                                                            |                                                                                                                                                                                             |
|                                                                                                                               |                                                                                                                                            |                                                                                                                                                                                             |
| START:                                                                                                                        |                                                                                                                                            |                                                                                                                                                                                             |
| LDC                                                                                                                           | #RAM_END+1,ISP                                                                                                                             | ; Sets initial value for stack pointer(ISP)                                                                                                                                                 |
| ,<br>MOV.B                                                                                                                    | #03H,PRCR                                                                                                                                  | ; Removes protection.                                                                                                                                                                       |
| MOV.W                                                                                                                         | #0183H,PM0                                                                                                                                 | ; Sets processor mode register 0 and 1.                                                                                                                                                     |
| 11                                                                                                                            | -                                                                                                                                          | ; Sets system clock control registers 0 and 1.<br>; Sets main clock divide register.                                                                                                        |
| MOV.B                                                                                                                         | #0,PRCR                                                                                                                                    | ; Protects all registers.                                                                                                                                                                   |
| ;<br>P * SO 7: Indianton t                                                                                                    | hat zoro format has been                                                                                                                   | a cloated for instruction format                                                                                                                                                            |
| 0XMSD S: Indicates t                                                                                                          | hat short format has been                                                                                                                  | n selected for instruction format. 3*4                                                                                                                                                      |
| Q: Indicates t                                                                                                                | that quick format has bee                                                                                                                  | en selected for instruction format.                                                                                                                                                         |
|                                                                                                                               |                                                                                                                                            | B relative addressing mode been =======                                                                                                                                                     |
|                                                                                                                               | DATA_TADEE[A0],NU                                                                                                                          |                                                                                                                                                                                             |
| MOV.W                                                                                                                         | #1234H,R1                                                                                                                                  |                                                                                                                                                                                             |
| DOEI                                                                                                                          | char_bu                                                                                                                                    |                                                                                                                                                                                             |
| •                                                                                                                             |                                                                                                                                            |                                                                                                                                                                                             |
| ; •                                                                                                                           |                                                                                                                                            |                                                                                                                                                                                             |
| ; .                                                                                                                           |                                                                                                                                            |                                                                                                                                                                                             |
| -                                                                                                                             |                                                                                                                                            |                                                                                                                                                                                             |
| ,                                                                                                                             |                                                                                                                                            |                                                                                                                                                                                             |
| ;=== S: Indicates tha                                                                                                         | t 3-bit relative jump (jump                                                                                                                | o distance specifier 'S') has been selected.                                                                                                                                                |
| W: Indicates that                                                                                                             | at 16-bit relative jump (jump                                                                                                              | np distance specifier 'W') has been selected.                                                                                                                                               |
|                                                                                                                               |                                                                                                                                            |                                                                                                                                                                                             |
| ;<br>•                                                                                                                        |                                                                                                                                            |                                                                                                                                                                                             |
|                                                                                                                               |                                                                                                                                            |                                                                                                                                                                                             |
| DATA_TABLE:<br>.BYTE                                                                                                          | 12H,34H,56H,78H                                                                                                                            | ; Sets 1 byte data.                                                                                                                                                                         |
| .BYTE<br>.WORD                                                                                                                | 1234H,5678H                                                                                                                                | ; Sets 2 bytes data.                                                                                                                                                                        |
| .BYTE<br>.WORD<br>.ADDR                                                                                                       | 1234H,5678H<br>123456H,789ABCH                                                                                                             | ; Sets 2 bytes data.<br>; Sets 3 bytes data.                                                                                                                                                |
| .BYTE<br>.WORD<br>.ADDR<br>.LWORD                                                                                             | 1234H,5678H                                                                                                                                | ; Sets 2 bytes data.<br>; Sets 3 bytes data.                                                                                                                                                |
| .BYTE<br>.WORD<br>.ADDR                                                                                                       | 1234H,5678H<br>123456H,789ABCH                                                                                                             | ; Sets 2 bytes data.<br>; Sets 3 bytes data.                                                                                                                                                |
| .BYTE<br>.WORD<br>.ADDR<br>.LWORD                                                                                             | 1234H,5678H<br>123456H,789ABCH                                                                                                             | ; Sets 2 bytes data.<br>; Sets 3 bytes data.                                                                                                                                                |
| .BYTE<br>.WORD<br>.ADDR<br>.LWORD                                                                                             | 1234H,5678H<br>123456H,789ABCH                                                                                                             | ; Sets 2 bytes data.<br>; Sets 3 bytes data.                                                                                                                                                |
| .BYTE<br>.WORD<br>.ADDR<br>.LWORD<br>DATA_TABLE_END:<br>;<br>;<br>;<br>.END                                                   | 1234H,5678H<br>123456H,789ABCH<br>12345678H,9ABCDEF                                                                                        | ; Sets 2 bytes data.<br>; Sets 3 bytes data.<br>; Sets 4 bytes data.                                                                                                                        |
| .BYTE<br>.WORD<br>.ADDR<br>.LWORD<br>DATA_TABLE_END:<br>;<br>;<br>.END                                                        | 1234H,5678H<br>123456H,789ABCH<br>12345678H,9ABCDEF<br>mber of errors derived fro                                                          | ; Sets 2 bytes data.<br>; Sets 3 bytes data.<br>; Sets 4 bytes data.                                                                                                                        |
| .BYTE<br>.WORD<br>.ADDR<br>.LWORD<br>DATA_TABLE_END:<br>;<br>;<br>.END                                                        | 1234H,5678H<br>123456H,789ABCH<br>12345678H,9ABCDEF<br>mber of errors derived fro<br>well as total number of wa                            | ; Sets 2 bytes data.<br>; Sets 3 bytes data.<br>; Sets 4 bytes data.                                                                                                                        |
| .BYTE<br>.WORD<br>.ADDR<br>.LWORD<br>DATA_TABLE_END:<br>;<br>;<br>.END                                                        | 1234H,5678H<br>123456H,789ABCH<br>12345678H,9ABCDEF<br>mber of errors derived fro<br>well as total number of wa                            | ; Sets 2 bytes data.<br>; Sets 3 bytes data.<br>; Sets 4 bytes data.                                                                                                                        |
| .BYTE<br>.WORD<br>.ADDR<br>.LWORD<br>DATA_TABLE_END:<br>;<br>.END<br>Outputs total num<br>assembling, as w<br>and total numbe | 1234H,5678H<br>123456H,789ABCH<br>12345678H,9ABCDEF<br>mber of errors derived fro<br>well as total number of wa<br>r of list lines.        | ; Sets 2 bytes data.<br>; Sets 3 bytes data.<br>; OH ; Sets 4 bytes data.                                                                                                                   |
| .BYTE<br>.WORD<br>.ADDR<br>.LWORD<br>DATA_TABLE_END:<br>;<br>.END<br>Outputs total num<br>assembling, as v<br>and total numbe | 1234H,5678H<br>123456H,789ABCH<br>12345678H,9ABCDEF<br>mber of errors derived fro<br>well as total number of wa<br>r of list lines.        | ; Sets 2 bytes data.<br>; Sets 3 bytes data.<br>; OH ; Sets 4 bytes data.                                                                                                                   |
| .BYTE<br>.WORD<br>.ADDR<br>.LWORD<br>DATA_TABLE_END:<br>;<br>.END<br>Outputs total num<br>assembling, as v<br>and total numbe | 1234H,5678H<br>123456H,789ABCH<br>12345678H,9ABCDEF<br>mber of errors derived fro<br>well as total number of wa<br>r of list lines.        | ; Sets 2 bytes data.<br>; Sets 3 bytes data.<br>; OH ; Sets 4 bytes data.                                                                                                                   |
|                                                                                                                               | char_b0<br>short_b1<br>addr_b2<br>long_b3<br>;<br>R * SOURCE LIST<br>0XMSDA **SOU<br>PAGE<br>;<br>SOU<br>PAGE<br>;<br>SOU<br>PAGE<br>;<br> | short_b1 .BTEQU 1,short<br>addr_b2 .BTEQU 2,addu<br>long_b3 .BTEQU 3,long<br>R* SOURCE LIST Wed Mar 24 16:04:39 1<br>0XMSDA .**SOURCE STATEMENT8<br>.PAGE<br>SOURCE STATEMENT8<br>.PAGE<br> |



# Assemble Error Tag File





# Appendix A-2 Linking(In308)

The following explains the files generated by the linkage editor In308 and how to start up the linkage editor.

#### Files Generated by In308

- (1) Absolute module file (\*\*\*.X30) ... Generated as necessary This file is based on IEEE-695. It consists of the relocatable module files output by as308 that have been edited into a single file.
- (2) Map file (\*\*\*.MAP) ... Generated when option '-M' or '-MS' is specified This file contains link information, section's last located address information, and symbol information. Symbol information is output to this map file only when an option '-MS' is specified.
- (3) Link error tag file (\*\*\*.TAG) ... Generated when option '-T' is specified This file contains error messages for errors that have occurred when linking the relocatable module files. This file is not generated when no error was encountered. This file allows errors to be corrected easily when it is used an editor that has the tag jump function.



# Method for Starting Up In308

#### >In308 relocatable file name [relocatable file name...] [option]

Be sure to write at least one file name. The extension (.R30) can be omitted.

#### Table A.2 Command Options of In308

| Command option        | Function                                                                                                                                                                                     |
|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                       | Inhibits link processing messages from being output.                                                                                                                                         |
| -E address value      | Sets start address of absolute module file. Always be sure to<br>insert space between option symbol and address value and<br>use label name or hexadecimal number to write address<br>value. |
| -G                    | Outputs source debug information to absolute module file.                                                                                                                                    |
| -L library file       | Specifies library file to be referenced when linking.                                                                                                                                        |
| -LD path name         | Specifies directory of library file.                                                                                                                                                         |
| -LOC                  | Allocates the data of a specified section from a specified address.                                                                                                                          |
| -M                    | Generates map file. This file is named after absolute module file by changing its extension to ".map".                                                                                       |
| -MS                   | Generates map file that includes symbol information.                                                                                                                                         |
| -MSL                  | The fullname of symbol more than 16 characters are output to map file.                                                                                                                       |
| -NOSTOP               | Outputs all encountered link errors to the screen. if this operation is not specified, outputs up to 20 errors to the sc reen.                                                               |
| -O absolute file name | Specifies absolute module file name. File extension can be omitted. If omitted, extension ".x30" is assumed.                                                                                 |
| -ORDER                | Specifies section arrangement and sequence in which order<br>they are located. If start address is not specified, sections<br>are<br>located beginning with address 0.                       |
| -Т                    | Outputs error tag file.                                                                                                                                                                      |
| -V                    | Displays version on screen. Linker is terminated without performing anything else.                                                                                                           |
| @Command file name    | Starts up In30 using specified file as command parameter.<br>Do not insert space between @ and command file name.<br>This option cannot be used with any other option<br>simultaneously.     |



# Example for Using In308 Commands



# Link Error Tag File



Note: Absolute module files are output in the format based on IEEE-695. Since this format is binary, the files cannot be output to the screen or printer; nor can they be edited.



# Map File

| -                                                                                                                             |
|-------------------------------------------------------------------------------------------------------------------------------|
| Figure A.5 shows an example of a map file.                                                                                    |
| ######################################                                                                                        |
| ####################################                                                                                          |
| ####################################                                                                                          |
| sym2       000000         ####################################                                                                |
| ####################################                                                                                          |
| ####################################                                                                                          |
| @ SMP (SMP.r30 )<br>addr_b2 2 000403 char_b0 0 000400 long_b3 3 000406<br>short_b1 1 000401<br>Figure A.5 Example of map file |



# Appendix A-3 Generating Machine Language File (Imc308)

The following explains the files generated by the load module converter Imc308 and how to start up the converter.

#### Files Generated by Imc308

- (1) Motorola S format file (\*\*\*.MOT) ... Generated normally This is a machine language file normally generated by the converter.
- (2) Intel HEX format file (\*\*\*.HEX) ... Generated when option '-H' is specified This is a machine language file generated by the converter when an option '-H' is specified.

#### Method for Starting Up Imc308

#### >Imc308 [option] absolute module file name

#### Table A.3 Command Options of Imc308

| Command option   | Function                                                                                                                                                                                                                                                                                                   |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | Inhibits all messages but error messages and warning messages from being output to the file.                                                                                                                                                                                                               |
| -E start address | Sets program's start address and generates machine<br>language file in<br>Motorola S format. This option cannot be specified<br>simultaneously with<br>option '-H'.                                                                                                                                        |
| -H               | Generates machine language file in extended Intel HEX format. This option cannot be specified simultaneously with option '-E'.                                                                                                                                                                             |
| -ID              | Sets ID code of ID code check function .<br>An ID file(extension .id) is created to display ID codes set<br>with this option.                                                                                                                                                                              |
| -L               | Sets data length that can be handled in S2 records to 32 bytes. Sets<br>Intel HEX format's data length to 32 bytes.                                                                                                                                                                                        |
| -0               | Specifies file name of machine language file generated by<br>Imc30. This file is generated in current directory. Always be<br>sure to insert space between option and machine language<br>file name. Extension of machine language file can be<br>omitted. (Motorola S format .mot; Intel HEX format .hex) |
| -V               | Displays version of Imc30 on screen. Converter is terminated without performing anything else.                                                                                                                                                                                                             |
| -PROTECT1        | Sets level 1 of ROM code protect function .                                                                                                                                                                                                                                                                |
| -PROTECT2        | Sets level 2 of ROM code protect function .                                                                                                                                                                                                                                                                |



# Example for Using Imc30 Commands





| REVISION HISTORY | ′ |
|------------------|---|
|                  |   |

Programming Guidelines <Assembly Language> Application Note

| Rev.         Date         Description           1.00         Oct 20, 2003         -         First edition issued           1.01         Sep 5, 2005         All page         Assembler Language> Assembly Language           Image: Imag                                                                                         |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 1.00 Oct 20, 2003 - First edition issued                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
| 1.01       Sep 5, 2005       All page       Assembler Language> Assembly Language         Image: Image and the set of the |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |

# Keep safety first in your circuit designs!

 Renesas Technology Corporation puts the maximum effort into making semiconductor products better and more reliable, but there is always the possibility that trouble may occur with them. Trouble with semiconductors may lead to personal injury, fire or property damage. Remember to give due consideration to safety when making your circuit designs, with appropriate measures such as (i) placement of substitutive, auxiliary circuits, (ii) use of nonflammable material or (iii) prevention against any malfunction or mishap.

# Notes regarding these materials

- These materials are intended as a reference to assist our customers in the selection of the Renesas Technology Corporation product best suited to the customer's application; they do not convey any license under any intellectual property rights, or any other rights, belonging to Renesas Technology Corporation or a third party.
- Renesas Technology Corporation assumes no responsibility for any damage, or infringement of any third-party's rights, originating in the use of any product data, diagrams, charts, programs, algorithms, or circuit application examples contained in these materials.
- All information contained in these materials, including product data, diagrams, charts, programs and algorithms represents information on products at the time of publication of these materials, and are subject to change by Renesas Technology Corporation without notice due to product improvements or other reasons. It is therefore recommended that customers contact Renesas Technology Corporation or an authorized Renesas Technology Corporation product distributor for the latest product information before purchasing a product listed herein.

The information described here may contain technical inaccuracies or typographical errors. Renesas Technology Corporation assumes no responsibility for any damage, liability, or other loss rising from these inaccuracies or errors.

Please also pay attention to information published by Renesas Technology Corporation by various means, including the Renesas Technology Corporation Semiconductor home page (http://www.renesas.com).

- When using any or all of the information contained in these materials, including product data, diagrams, charts, programs, and algorithms, please be sure to evaluate all information as a total system before making a final decision on the applicability of the information and products. Renesas Technology Corporation assumes no responsibility for any damage, liability or other loss resulting from the information contained herein.
- Renesas Technology Corporation semiconductors are not designed or manufactured for use in a device or system that is used under circumstances in which human life is potentially at stake. Please contact Renesas Technology Corporation or an authorized Renesas Technology Corporation product distributor when considering the use of a product contained herein for any specific purposes, such as apparatus or systems for transportation, vehicular, medical, aerospace, nuclear, or undersea repeater use.
- The prior written approval of Renesas Technology Corporation is necessary to reprint or reproduce in whole or in part these materials.
- If these products or technologies are subject to the Japanese export control restrictions, they must be exported under a license from the Japanese government and cannot be imported into a country other than the approved destination. Any diversion or reexport contrary to the export control laws and regulations of Japan and/ or the country of destination is prohibited.
- Please contact Renesas Technology Corporation for further details on these materials or the products contained therein.

**(ENESAS**